FTP服务器的两种工作模式

本文详细介绍了FTP(File Transfer Protocol)协议的工作原理,包括主动模式和被动模式的区别,以及如何通过命令连接和数据连接进行文件传输。深入探讨了FTP服务的配置与管理,以及不同模式下可能遇到的网络问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

FTP协议:
FTP(File transfer Protocol)是一种在互联网中进行文件传输的协议,基于客户端/服务器模式,默认使用20、21号端口,
其中端口20(数据端口)用于进行数据传输,端口21(命令端口)用于接受客户端发出的相关FTP命令与参数。
FTP服务器一般部署于内网中,具有容易搭建、方便管理的特点。而且有些FTP客户端工具还可以支持文件的多点下载以及断点续传技术,因此FTP服务得到了广大用户的青睐。

Ftp有两种工作模式:
主动模式(PORT):服务器主动向客户端发起连接请求.
被动模式(PAVS):FTP服务器等待客户端发起连接请求(FTP的默认工作模式).

Ftp协议需要用到两个TCP连接:
命令连接:用来在FTP客户端与服务器之间传递命令。
数据连接:用来在服务器和客户端进行文件传输。

无论是主动模式还是被动模式,其要进行文件传输都必须依次建立两个连接,分别为命令连接与数据连接。而主动模式与被动模式的差异主要体现在数据连接通道上。

命令连接:

当FTP客户端需要登陆到FTP服务器上的时候,服务器与客户端需要进行一系列的身份验证过程,这个过程就叫做命令连接。
如在客户端向服务器发起连接请求的时候,客户端会随即的选择某个TCP端口来跟FTP服务器的21号端口进行连接,这主要是通过TCP三方握手来实现的。当三方握手完成之后,客户端与 服务器之间便建立了命令连接通道。不过这个通道的用途是非常有限的,其主要用来传输FTP的相关指令。如查看文件列表、删除文件等等,而不能够用来在客户 端与服务端进行文件传输

数据连接:

在命令连接通道建立以后,如果想要在ftp服务器和客户端之间传输文件,则需要建立数据连接通道。

根据建立数据连接是由谁发起的可以分为主动模式(PROT)和被动模式(PAVS)

主动模式:
主动模式流程
主动模式优点
服务端配置简单,利于服务器安全管理,服务器只需要开放21端口
缺点
如果客户端开启了防火墙,或客户端处于内网(NAT网关之后), 那么服务器对客户端端口发起的连接可能会失败

被动模式:
被动模式流程
被动模式通常用在处于防火墙之后的FTP客户访问外界FTp服务器的情况,因为在这种情况下,防火墙通常配置为不允许外界访问防火墙之后主机,而只允许由防火墙之后的Ftp客户端发起的连接请求通过。因此,在这种情况下不能使用主动模式的FTP传输,而被动模式的FTP可以良好的工作。
优点
对客户端网络环境没有要求
缺点
服务器配置管理稍显复杂,不利于安全,服务器需要开放随机高位端口以便客户端可以连接,因此大多数FTP服务软件都可以手动配置被动端口的范围

### FTP服务器工作原理 FTP(文件传输协议)用于在网络上进行文件的上传和下载操作。FTP通过两个独立的TCP连接来完成数据交换:一个是控制连接,另一个是数据连接。 #### 控制连接与数据连接 - **控制连接**:负责传递命令和状态码,在整个会话期间保持打开状态。 - **数据连接**:专门用来传送实际的数据流,每次有新的数据传输需求时建立并使用完毕即关闭[^1]。 #### 工作模式详解 FTP支持两种主要的工作模式: ##### 主动模式 (Active Mode) 在这种模式下,客户端向服务器发起请求,并告知自己的端口号以便接收返回的数据。具体过程如下: - 客户端先与服务器建立一条控制通道,默认端口为21; - 当准备就绪要传输数据前,客户端发送`PORT`指令给服务器,指明自己监听哪个本地端口等待来自服务器的数据连接; - 之后由服务器主动尝试连接至该指定地址及端口以创建数据链路; ```python from ftplib import FTP ftp = FTP('example.com') ftp.login(user='username', passwd ='password') # 设置为主动模式 ftp.set_pasv(False) ``` ##### 被动模式 (Passive Mode / PASV) 为了适应防火墙环境下的通信场景而设计的一种改进型交互方式。其特点是让服务器提供一个临时端口供客户端去连接而不是相反方向的操作。流程描述为: - 同样地初始化阶段也是利用标准端口21构建起控制层面的对话; - 接着当需要开启资料管道的时候,则是由客户机发出`PASV`请求; - 此刻服务机会回应一段含有内部IP加上开放埠位的信息字符串; - 最终依据上述信息构造出通往目标机器的新路径从而实现双向沟通的目的。 ```python from ftplib import FTP ftp = FTP('example.com') ftp.login(user='username', passwd ='password') # 设置为被动模式 ftp.set_pasv(True) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值