阿里云 ECS 七天进阶训练营-搭建 FTP 篇

主机搭建 FTP 服务

  1. 安装 FTP 服务

    ```yum install -y vsftpd```
    
  2. 设置开机启动

    ```systemctl enable vsftpd.service```
    
  3. 启动 FTP 服务

    ```systemctl start vsftpd.service```
    
  4. 查看后台进程 FTP 是否已经启动

    ```netstat -antup | grep ftp```
    
  5. 放开匿名上传权限注 #anon_upload_enable=YES
    vim /etc/vsftpd/vsftpd.conf

阿里云 ECS 七天进阶训练营-搭建 FTP 篇

  1. 更改/var/ftp/pub目录的权限,为 FTP 用户添加写权限
    chmod o+w /var/ftp/pub/
  2. 重启 FTP 服务
    systemctl restart vsftpd.service
  3. 创建本地用户登录模式

    adduser haogege
    passwd haogege # 输入密码   
  4. 创建一个供FTP服务使用的文件目录
    mkdir /var/ftp/test
  5. 更改/var/ftp/test目录的拥有者为 haogege
    chown -R haogege:haogege /var/ftp/test
  6. 修改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 文件,添加例外用户名单。此名单中的用户不会被锁定在主目录,可以访问其他目录。
  1. 重启 FTP 服务
    systemctl restart vsftpd.service
  2. 登陆测试
    注:浏览器登陆可以不加端口 :21

阿里云 ECS 七天进阶训练营-搭建 FTP 篇
登陆成功
阿里云 ECS 七天进阶训练营-搭建 FTP 篇

  1. 总结

    • vsftp分为主动模式与被动模式(传输模式上的差别)

      • 当处于主动模式时,客户端连接服务器端的21端口,发送用户名密码,服务器接收到信息后通过20端口与客户端连接
      • 当处于被动模式时,客户端连接到服务器端的21端口,发送用户名密码,服务器端会随机开放一个1024以上的端口,告诉客户端,让它连接

    不论主动模式还是被动模式,都是用21端口发送指令,只是传输数据通道的区别。

    • 使用被被动模式时

      • 注意配置被动模式的 IP 地址
上一篇:k8s 上 go 服务实战: 使用 helm 快速构建云原生应用


下一篇:《淘宝店铺 大数据营销+SEO+爆款打造 一册通》一一1.5 店铺页面装修分析