常见原因:FTP服务未运行、防火墙阻止端口、配置文件错误。
解决方案:
sudo systemctl status vsftpd
,若未运行则用sudo systemctl start vsftpd
启动服务。sudo ufw allow 20/tcp
sudo ufw allow 21/tcp
sudo ufw allow 30000:31000/tcp # 被动模式端口范围
sudo ufw reload
/etc/vsftpd.conf
中的关键参数:listen=YES
(启用监听)、anonymous_enable=NO
(禁止匿名)、local_enable=YES
(允许本地用户登录)。修改后重启服务:sudo systemctl restart vsftpd
。常见原因:用户无写入权限、write_enable
未开启、磁盘空间不足。
解决方案:
sudo chown ftpuser:ftpuser /home/ftpuser # 将目录所有者设为用户
sudo chmod 755 /home/ftpuser # 允许所有者写入
/etc/vsftpd.conf
中设置write_enable=YES
,重启服务生效。df -h
查看磁盘使用情况,清理无用文件释放空间。常见原因:网络不通、防火墙拦截、被动模式端口未开放。
解决方案:
ping <服务器IP>
检查客户端与服务器的网络连接。/etc/vsftpd.conf
中启用被动模式并设置端口范围:pasv_enable=YES
pasv_min_port=30000
pasv_max_port=31000
重启服务后,客户端需在FTP客户端(如FileZilla)中设置相同的被动模式端口范围。常见原因:客户端与服务器字符集不匹配(如Windows用GBK、Linux用UTF-8)。
解决方案:
UTF-8
。/etc/vsftpd.conf
中添加char_set=UTF-8
,重启服务。常见原因:证书路径错误、TLS未启用、配置文件参数错误。
解决方案:
sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/ssl/private/vsftpd.key -out /etc/ssl/private/vsftpd.crt
/etc/vsftpd.conf
中添加以下参数:ssl_enable=YES
ssl_tls=YES
rsa_cert_file=/etc/ssl/private/vsftpd.crt
rsa_private_key_file=/etc/ssl/private/vsftpd.key
重启服务后,客户端需选择“FTP over TLS”模式连接。常见原因:配置文件被误删、参数设置错误。
解决方案:
sudo apt remove --purge vsftpd
sudo apt install vsftpd
/etc/vsftpd.conf
后,用sudo vsftpd /etc/vsftpd.conf
测试配置是否正确,若有错误会提示具体行号。常见原因:端口冲突、配置文件语法错误、依赖服务未启动。
解决方案:
sudo netstat -tuln | grep 21
,若21端口被占用,修改/etc/vsftpd.conf
中的listen_port
为其他端口(如2121),并更新防火墙规则。journalctl -xe
或sudo systemctl status vsftpd
查看启动错误信息,根据提示修复(如配置文件语法错误)。常见原因:允许匿名登录、用户口令简单、未限制用户访问范围。
解决方案:
/etc/vsftpd.conf
中设置anonymous_enable=NO
。chroot_local_user=YES
将用户限制在主目录,添加allow_writeable_chroot=YES
允许写入(若需上传文件)。sudo passwd -e ftpuser
强制用户定期修改口令,或通过/etc/pam.d/vsftpd
配置强密码策略。