首先更新系统软件包并安装vsftpd:
sudo apt update && sudo apt upgrade -y
sudo apt install vsftpd -y
/etc/vsftpd.conf)编辑vsftpd主配置文件,调整以下核心参数以提升安全性:
anonymous_enable=NO
local_enable=YES
NO)。write_enable=YES
chroot_local_user=YES
allow_writeable_chroot=YES # 允许chroot目录可写(避免“550 Failed to change directory”错误)
pasv_enable=YES
pasv_min_port=50000
pasv_max_port=50010
anon_upload_enable=NO
anon_mkdir_write_enable=NO
anon_other_write_enable=NO
为避免数据传输被窃听,需配置TLS加密(使用自签名证书或权威机构颁发的证书):
sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/ssl/private/vsftpd.pem -out /etc/ssl/private/vsftpd.pem
ssl_enable=YES
force_local_data_ssl=YES
force_local_logins_ssl=YES
ssl_tlsv1=YES
ssl_sslv2=NO
ssl_sslv3=NO
rsa_cert_file=/etc/ssl/private/vsftpd.pem
rsa_private_key_file=/etc/ssl/private/vsftpd.pem
通过userlist功能控制允许访问FTP的用户列表:
sudo nano /etc/vsftpd.userlist
添加允许登录的用户名(每行一个),例如:ftpuser1
ftpuser2
userlist_deny=NO表示仅允许列表内的用户登录)。userlist_enable=YES
userlist_file=/etc/vsftpd.userlist
userlist_deny=NO
使用ufw(Uncomplicated Firewall)允许FTP流量及被动模式端口:
sudo ufw allow 20/tcp # FTP数据连接(主动模式)
sudo ufw allow 21/tcp # FTP控制连接
sudo ufw allow 50000:50010/tcp # 被动模式端口范围
sudo ufw enable # 启用防火墙
应用配置更改并重启vsftpd服务:
sudo systemctl restart vsftpd
sudo systemctl enable vsftpd # 设置开机自启
使用FTP客户端(如FileZilla)连接服务器,验证:
启用详细日志记录,便于追踪FTP活动及排查安全事件:
xferlog_enable=YES
xferlog_std_format=YES
xferlog_file=/var/log/vsftpd.log
定期检查日志文件:
sudo tail -f /var/log/vsftpd.log
注意事项: