Ubuntu 上使用 vsftpd 进行安全高效的数据传输
一 安装与基础配置
sudo apt update && sudo apt install vsftpdlocal_enable=YES、write_enable=YESxferlog_enable=YES、connect_from_port_20=YESchroot_local_user=YES、allow_writeable_chroot=YESpam_service_name=vsftpd、userlist_enable=YESsudo systemctl restart vsftpd二 启用加密传输 FTPS
sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/ssl/private/vsftpd.pem -out /etc/ssl/private/vsftpd.pemssl_enable=YESforce_local_logins_ssl=YES、force_local_data_ssl=YESssl_tlsv1=YES、ssl_sslv2=NO、ssl_sslv3=NOrsa_cert_file=/etc/ssl/private/vsftpd.pem、rsa_private_key_file=/etc/ssl/private/vsftpd.pemsudo ufw allow 21/tcp、sudo ufw allow 990/tcp三 被动模式与防火墙设置
pasv_enable=YES、pasv_min_port=40000、pasv_max_port=50000sudo ufw allow 40000:50000/tcppasv_address=你的公网IP四 性能优化与限速
max_clients=50、max_per_ip=10local_max_rate=0(不限制)、anon_max_rate=0pasv_enable=YES 并固定端口段,减少连接建立开销sudo systemctl restart vsftpd五 常见问题与排查
local_enable=YES、write_enable=YES、chroot_local_user=YES 与目录权限;若启用 chroot 且需写,设置 allow_writeable_chroot=YESpasv_min_port/pasv_max_port 与防火墙放行;NAT 下设置 pasv_addresssudo tail -f /var/log/vsftpd.logvsftpd -v,无误后重启服务