转:https://blog.csdn.net/ygwlove0110/article/details/88232065

遇到了个坑。服务器开启了防火墙后,ftp客户端连接就无法显示目录。关掉防火墙就可以啦。

当然防火墙还是要开启的现在贴出来解决方法

vsftpd.conf文件 的部分配置

pam_service_name=vsftpd
userlist_enable=YES
tcp_wrappers=YES
#以上是默认配置 chroot_local_user=YES
chroot_list_enable=NO
chroot_list_file=/etc/vsftpd/chroot_list
##配置自定义的端口 如果需要修改就需要修改 /etc/service 对应的端口 并开启防火墙端口
listen_port=
local_root=/var/ftp/public ###以下是解决开启防火墙后不可以用,添加的内容
pasv_enable=YES
pasv_min_port=
pasv_max_port=
pasv_promiscuous=YES

同时需要开启防火墙的放行

firewall-cmd --permanent --zone=public --add-port=40000-40080/tcp
firewall-cmd --reload

  最后重启ftp服务

systemctl restart vsftpd.service

  使用ftp工具测试防火可以啦

05-14 23:26