ftp文件传输协议在哪里:FTP文件传输协议的主动模式与被动模式

ftp文件传输协议在哪里:FTP文件传输协议的主动模式与被动模式(1)

FTP(File Transfer Protocol/文件传输协议),是提供上传及下载文件的服务。

FTP是基于TCP协议的服务,而在FTP服务器和客户端建立连接时,有两种模式主动模式(Active)和被动模式(Passive)。

FTP工作原理

FTP服务使用两个端口在服务器和客户端之间进行通信。 一个是控制端口(也叫命令端口),用来传输指令和命令,命令端口通常是21。另一个是数据端口,用来传输实际的数据。

主动模式与被动模式的区别,主要在数据端口上。

FTP主动模式

主动模式建立连接的过程如下:

1. 客户端打开一个随机的端口N(端口号大于1024),连接至FTP服务器的21号命令端口。 客户端开始监听端口N 1,并通知FTP服务器客户端正在监听的端口号并且已准备好从此端口接收数据。 2. FTP服务器打开20号端口并且建立和客户端数据端口的连接。 3. 客户端向FTP服务器发送一个应答,告诉FTP服务器它已经建立好了一个连接。

主动模式下的工作方式:

命令连接:客户端 ( >1024端口) -> FTP服务器 (21端口) 数据连接:客户端( >1024端口)

ftp文件传输协议在哪里:FTP文件传输协议的主动模式与被动模式(2)

总结一下,主动模式下数据连接是由FTP服务器端发起。

使用主动模式的情况下,在防火墙或NAT环境下,容易产生一些问题,导致无法连接。比如:FTP服务器企图与客户端的高位随机端口建立连接,而这个端口很有可能被客户端的防火墙阻塞掉。所以产生了从客户端发起连接的被动模式。

FTP被动模式

被动模式建立连接的过程如下:

1. 客户端打开一个随机的端口N(端口号大于1024),连接至FTP服务器的21号命令端口。 客户端打开一个随机的端口N 1,并向FTP服务器发送PASV命令。 2. FTP服务器打开一个任意的非特权端口P(端口号大于1024)并将端口号通知客户端。 3. 客户端发起从本地端口N 1到FTP服务器的端口P的连接用来传送数据。

被动模式下的工作方式:

命令连接:客户端 ( >1024端口) -> FTP服务器 (21端口) 数据连接:客户端( >1024端口) -> FTP服务器 (>1024端口)

ftp文件传输协议在哪里:FTP文件传输协议的主动模式与被动模式(3)

被动模式下,命令连接和数据连接都由客户端发起。

这样就可以解决主动模式下从FTP服务器发起的数据连接的端口被防火墙阻塞掉的问题。

解决通过防火墙连接FTP的问题

在FTP服务器端开启被动模式需要进行如下的设置(以vsftpd为例):

pasv_enable=YES #FTP服务器使用被动模式 pasv_min_port=60000 #定义数据连接端口号开始范围 pasv_max_port=60100 #定义数据连接端口号结束范围

在防火墙上要添加允许从60000到60100端口的入站规则。

解决关于NAT的问题

有两种方法:

  1. 在防火墙上启用FTP的ALG功能
  2. 在FTP服务器端指定地址进行地址转换

以vsftpd为例,配置FTP服务器端指定地址进行地址转换。

pasv_addr_resolve=YES #启用地址转换 pasv_address=xx.xx.xx.xx #FTP服务器公网地址

,

免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com

    分享
    投诉
    首页