可能原因:FTP服务未运行、防火墙阻止端口、配置文件错误。
解决方案:
sudo systemctl status vsftpd确认服务是否启动(显示“active (running)”为正常);若未启动,用sudo systemctl start vsftpd启动服务。ufw防火墙,运行sudo ufw allow 20/tcp(FTP数据端口)、sudo ufw allow 21/tcp(FTP控制端口)、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设置目录权限(若需写入,可改为775)。df -h查看磁盘使用情况,若空间不足,清理无用文件(如/var/log下的旧日志)。/etc/vsftpd.conf,确保write_enable=YES,修改后重启vsftpd服务。可能原因:证书路径错误、TLS未启用、证书过期。
解决方案:
/etc/vsftpd.conf中ssl_enable=YES(启用TLS)、ssl_tlsv1=YES(支持TLSv1协议)、rsa_cert_file=/etc/ssl/private/vsftpd.crt(证书路径)、rsa_private_key_file=/etc/ssl/private/vsftpd.key(私钥路径)正确;若证书不存在,用sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/ssl/private/vsftpd.key -out /etc/ssl/private/vsftpd.crt生成自签名证书。force_local_data_ssl=YES、force_local_logins_ssl=YES,提升安全性。可能原因:网络不通、防火墙阻止、被动模式端口未开放。
解决方案:
ping <服务器IP>,若无法ping通,检查网络设置或联系ISP。/etc/vsftpd.conf,设置pasv_enable=YES(启用被动模式)、pasv_min_port=30000(被动模式最小端口)、pasv_max_port=31000(被动模式最大端口);然后在防火墙中开放该端口范围(sudo ufw allow 30000:31000/tcp)。netstat -tuln | grep 21,确认vsftpd正在监听21端口;若未监听,检查配置文件中的listen=YES是否开启。可能原因:客户端与服务端字符集不匹配(如Windows用GBK、Linux用UTF-8)。
解决方案:
/etc/vsftpd.conf,添加char_set=UTF-8(设置服务端字符集为UTF-8);若客户端为Windows,可在FileZilla中进入“编辑→设置→传输→文件类型”,将“默认本地字符集”改为“GBK”。可能原因:误删除、修改错误导致配置文件无法使用。
解决方案:
sudo apt-get remove vsftpd --purge彻底删除vsftpd,再用sudo apt-get install vsftpd重新安装,系统会生成默认配置文件(/etc/vsftpd.conf)。sudo cp /etc/vsftpd.conf /etc/vsftpd.conf.bak),再根据需求修改关键参数(如local_enable=YES、write_enable=YES)。可能原因:主目录权限过严、chroot设置冲突。
解决方案:
sudo chown ftpuser:ftpuser /home/ftpuser将用户主目录所有权赋予该用户,用sudo chmod 755 /home/ftpuser设置目录权限(确保用户可读取和执行)。chroot设置:若启用了chroot_local_user=YES(限制用户在其主目录),需添加allow_writeable_chroot=YES(允许chroot环境写入),否则用户无法上传文件。可能原因:未配置IP限制规则。
解决方案:
/etc/hosts.allow,添加vsftpd: 192.168.1.100(允许特定IP访问);编辑/etc/hosts.deny,添加vsftpd: ALL(拒绝其他IP访问)。user_list文件:编辑/etc/vsftpd.conf,设置userlist_enable=YES、userlist_file=/etc/vsftpd.user_list、userlist_deny=NO(仅允许user_list中的用户访问);然后在/etc/vsftpd.user_list中添加允许的用户。