zoukankan      html  css  js  c++  java
  • [svc]ftp协议数据连接的2种模式

    玩明白了以太网2的二层数据格式, ip格式 tcp/udp个时候, 需要玩一玩一些有用的基于这些已上的协议数据了. 如 dhcp ftp等.比较有趣.

    ftp协议

    分控制连接21端口 和数据连接 20端口

    数据连接站在服务端角度来讲分两种模式: 主动模式(服务端主动用自己的20端口去连客户端,适合防火墙)
    被动模式(服务端被动等客户端来连服务端的一个随机端口.)

    每个协议都有控制层面(对应控制报文),和数据层面(对应的传输数据,有些只有控制层面,如dhcp不需要传数据)

    FTP服务端会监听2个端口, 控制进程20,数据进程21(主动模式)
    
    数据连接,站在服务器角度,有2种模式:
        主动模式:ftp server从20端口主动向客户端发起连接,由于源端口固定,所以适用于模式防火墙模式.
        被动模式:ftp server被动等待客户端来连我的这个端口(控制连接后会告知会将passive ip/port告知了客户端)
    一般情况下默认都是被动模式
    

    ftp两种模式

    原图和两枚ftp数据包: https://github.com/lannyMa/scripts/tree/master/pkgs/ftp

    主动模式数据交互过程

    14.1 客户端 14.128服务端

    • 建立控制连接,3次握手, 客户端连服务端21端口

    • 待连接建立后,客户端告知服务端 active ip/port

    • 服务端主动和客户端建立数据连接(站在服务端角度,是服务端主动去找客户端)

    • 传输数据

    • 断开数据连接

    • 断开控制连接

    被动模式数据交互过程

    • 客户端主动去和服务端建立控制连接

    • 服务端告知客户端passive mode /ip/port

    • 客户端主动去和服务端建立数据连接(站在服务端角度,是服务端被动等客户端)

    • 客户端和服务端之间断开数据连接

    • 客户端和服务端之间断开控制连接

  • 相关阅读:
    基于redis实现的延迟消息队列
    Redis实现求交集操作结果缓存的设计方案
    限流算法之漏桶算法、令牌桶算法
    Apache设置防DDOS模块mod_evasive
    FastCGI技术
    详解强大的SQL注入工具——SQLMAP
    nginx根据域名做http,https分发
    Nginx配置SSL证书部署HTTPS网站
    JProfiler学习笔记
    Mysql压测工具mysqlslap 讲解
  • 原文地址:https://www.cnblogs.com/iiiiher/p/8311458.html
Copyright © 2011-2022 走看看