主机搭建 FTP 服务
-
安装 FTP 服务
```yum install -y vsftpd```
-
设置开机启动
```systemctl enable vsftpd.service```
-
启动 FTP 服务
```systemctl start vsftpd.service```
-
查看后台进程 FTP 是否已经启动
```netstat -antup | grep ftp```
- 放开匿名上传权限注 #anon_upload_enable=YES
vim /etc/vsftpd/vsftpd.conf
- 更改/var/ftp/pub目录的权限,为 FTP 用户添加写权限
chmod o+w /var/ftp/pub/
- 重启 FTP 服务
systemctl restart vsftpd.service
-
创建本地用户登录模式
adduser haogege passwd haogege # 输入密码
- 创建一个供FTP服务使用的文件目录
mkdir /var/ftp/test
- 更改/var/ftp/test目录的拥有者为 haogege
chown -R haogege:haogege /var/ftp/test
- 修改vsftpd.conf配置文件
## 主动模式
sed -i 's/anonymous_enable=YES/anonymous_enable=NO/' /etc/vsftpd/vsftpd.conf #禁止匿名登录FTP服务器
sed -i 's/listen=NO/listen=YES/' /etc/vsftpd/vsftpd.conf #监听IPv4 sockets
sed -i 's/listen_ipv6=YES/#listen_ipv6=YES/' /etc/vsftpd/vsftpd.conf #关闭监听IPv6 sockets
sed -i 's/#chroot_local_user=YES/chroot_local_user=YES/' /etc/vsftpd/vsftpd.conf #全部用户被限制在主目录
sed -i 's/#chroot_list_enable=YES/chroot_list_enable=YES/' /etc/vsftpd/vsftpd.conf #启用例外用户名单
sed -i 's/#chroot_list_file=/chroot_list_file=/' /etc/vsftpd/vsftpd.conf #指定例外用户列表文件,列表中的用户不被锁定在主目录
echo "allow_writeable_chroot=YES" >> /etc/vsftpd/vsftpd.conf
echo "local_root=/var/ftp/test" >> /etc/vsftpd/vsftpd.conf #设置本地用户登录后所在的目录
## 被动模式
sed -i 's/anonymous_enable=YES/anonymous_enable=NO/' /etc/vsftpd/vsftpd.conf #禁止匿名登录FTP服务器
sed -i 's/listen=NO/listen=YES/' /etc/vsftpd/vsftpd.conf #监听IPv4 sockets
sed -i 's/listen_ipv6=YES/#listen_ipv6=YES/' /etc/vsftpd/vsftpd.conf #关闭监听IPv6 sockets
sed -i 's/#chroot_local_user=YES/chroot_local_user=YES/' /etc/vsftpd/vsftpd.conf #全部用户被限制在主目录
sed -i 's/#chroot_list_enable=YES/chroot_list_enable=YES/' /etc/vsftpd/vsftpd.conf #启用例外用户名单
sed -i 's/#chroot_list_file=/chroot_list_file=/' /etc/vsftpd/vsftpd.conf #指定例外用户列表文件,列表中的用户不被锁定在主目录
echo "allow_writeable_chroot=YES" >> /etc/vsftpd/vsftpd.conf
echo "local_root=/var/ftp/test" >> /etc/vsftpd/vsftpd.conf #设置本地用户登录后所在的目录
echo "pasv_enable=YES" >> /etc/vsftpd/vsftpd.conf #开启被动模式
echo "pasv_address=<FTP服务器公网IP地址>" >> /etc/vsftpd/vsftpd.conf #本教程中为ECS服务器弹性IP
echo "pasv_min_port=20" >> /etc/vsftpd/vsftpd.conf #设置被动模式下,建立数据传输可使用的端口范围的最小值
echo "pasv_max_port=21" >> /etc/vsftpd/vsftpd.conf #设置被动模式下,建立数据传输可使用的端口范围的最大值
#使用 touch 命令创建 chroot_list 文件,添加例外用户名单。此名单中的用户不会被锁定在主目录,可以访问其他目录。
- 重启 FTP 服务
systemctl restart vsftpd.service
- 登陆测试
注:浏览器登陆可以不加端口 :21
登陆成功
-
总结
-
vsftp分为主动模式与被动模式(传输模式上的差别)
- 当处于主动模式时,客户端连接服务器端的21端口,发送用户名密码,服务器接收到信息后通过20端口与客户端连接
- 当处于被动模式时,客户端连接到服务器端的21端口,发送用户名密码,服务器端会随机开放一个1024以上的端口,告诉客户端,让它连接
不论主动模式还是被动模式,都是用21端口发送指令,只是传输数据通道的区别。
-
使用被被动模式时
- 注意配置被动模式的 IP 地址
-