Linux—FTP服务原理及配置

FTP服务原理及配置

1.FTP定义

FTP(File Transfer Protocol,文件传输协议) 是 TCP/IP 协议组中的协议之一。FTP协议包括两个组成部分,其一为FTP服务器,其二为FTP客户端。其中FTP服务器用来存储文件,用户可以使用FTP客户端通过FTP协议访问位于FTP服务器上的资源。在开发网站的时候,通常利用FTP协议把网页或程序传到Web服务器上。此外,由于FTP传输效率非常高,在网络上传输大的文件时,一般也采用该协议。
默认情况下FTP协议使用TCP端口中的 20和21这两个端口,其中20用于传输数据,21用于传输控制信息。但是,是否使用20作为传输数据的端口与FTP使用的传输模式有关,如果采用主动模式,那么数据传输端口就是20;如果采用被动模式,则具体最终使用哪个端口要服务器端和客户端协商决定。

2.FTP工作原理

FTP支持两种模式,一种方式叫做Standard (也就是 PORT方式,主动方式),一种是 Passive(也就是PASV,被动方式)。 Standard模式 FTP的客户端发送 PORT 命令到FTP服务器。Passive模式FTP的客户端发送 PASV命令到 FTP Server。
下面介绍一下这两种方式的工作原理:
Port
FTP 客户端首先和FTP服务器的TCP 21端口建立连接,通过这个通道发送命令,客户端需要接收数据的时候在这个通道上发送PORT命令。 PORT命令包含了客户端用什么端口接收数据。在传送数据的时候,服务器端通过自己的TCP 20端口连接至客户端的指定端口发送数据。 FTP server必须和客户端建立一个新的连接用来传送数据。
Passive
在建立控制通道的时候和Standard模式类似,但建立连接后发送的不是Port命令,而是Pasv命令。FTP服务器收到Pasv命令后,随机打开一个高端端口(端口号大于1024)并且通知客户端在这个端口上传送数据的请求,客户端连接FTP服务器此端口,通过三次握手建立通道,然后FTP服务器将通过这个端口进行数据的传送。
很多防火墙在设置的时候都是不允许接受外部发起的连接的,所以许多位于防火墙后或内网的FTP服务器不支持PASV模式,因为客户端无法穿过防火墙打开FTP服务器的高端端口;而许多内网的客户端不能用PORT模式登陆FTP服务器,因为从服务器的TCP 20无法和内部网络的客户端建立一个新的连接,造成无法工作。

在Linux中FTP配置

1.FTP匿名账户的部署过程:

1、关闭防火墙和核心防护,并安装vsftp

在这里插入图片描述

2、修改属主和属组,并创建文件

在这里插入图片描述

在这里插入图片描述

3、修改配置文件为匿名用户登录

在这里插入图片描述

4、开启ftp服务,并查看端口号

在这里插入图片描述

5、用客户机连接

在这里插入图片描述

6、下载并上传文件

在这里插入图片描述

2、FTP本地用户的部署过程:

允许普通用户登陆:

1、配置文件

在这里插入图片描述

2、开启服务并添加用户尝试
在这里插入图片描述

3、在lisi目录下创建一个文件

在这里插入图片描述

4、用客户机连接

在这里插入图片描述

5、下载和上传文件

在这里插入图片描述

在这里插入图片描述

6、进宿主目录查看

在这里插入图片描述

允许白名单用户登陆:

1、配置文件

在这里插入图片描述

2、创建用户liming,并修改属主,属组和权限

在这里插入图片描述

3、在/opt/liming下创建文件

在这里插入图片描述

4、添加白名单

在这里插入图片描述

5、重启服务并查看端口号

![在这里插入图片描述](https://img-blog.csdnimg.cn/2020110516453187.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L20wXzUwNjUwOTUz,size_16,color_FFFFFF,t_70#pic_center

6、上传并下载文件

在这里插入图片描述

在这里插入图片描述

7、进宿主目录查看

在这里插入图片描述