CentOS 系统中,默认的FTP软件是vsftp,以下是安装配置过程。
先看一下系统中有没有运行vsftpd服务
没有的话,安装vsftpd包
[root@localhost~]#yuminstallvsftpd
[root@localhost~]#ll/etc/vsftpd/ 总用量40 -rw-------.1rootroot1253月2220:14ftpusers -rw-------.1rootroot3664月719:18user_list -rw-------.1rootroot48024月722:36vsftpd.conf -rwxr--r--.1rootroot3383月2220:14vsftpd_conf_migrate.sh
ftpusers文件中包含的用户账户将被禁止登录ftp服务器,不管该用户是否在user_list文件中出现
user_list文件中包含的用户账户可能被禁止登录,也可能被允许登录。在主配置文件中存在user_list=YES配置项时,该文件生效。如果user_deny=YES,则仅禁止列表中的用户登录。如果user_deny=NO,则仅允许列表中的用户登录
主配置文件vsftpd.conf中有很多配置项
vsftpd服务器同时支持匿名用户、本地用户和虚拟用户三类用户账号。我们仅用本地账号登录ftp服务器
1.新建一个用户并设置密码
[root@localhost~]#useraddlaya [root@localhost~]#passwdlaya
2.新建一个测试文件
[root@localhost~]#ls-lh/etc/*.conf>/home/laya/etcconf.list
[root@localhost~]#vim/etc/vsftpd/vsftpd.conf anonymous_enable=NO#不允许匿名用户登录 local_enable=YES#允许本地用户登录 write_enable=YES#开放写权限 local_umask=022#设置本地用户上传建立文件夹时的权限掩码 dirmessage_enable=YES#用户切换进入目录时显示.message文件 xferlog_enable=YES#启用xferlog日志 connect_from_port_20=YES#允许服务器主动模式 xferlog_std_format=YES#启用标准的xferlog日志格式 chroot_local_user=YES#安全起见,将用户禁锢在宿主目录中 listen=YES#以独立运行方式监听服务 pam_service_name=vsftpd#设置用于用户认证的PAM文件位置 userlist_enable=YES#启用user_list列表文件 userlist_deny=NO#允许user_list文件中的用户登录 tcp_wrappers=YES#启用TCP_Wrappers主机访问控制 max_clients=20#限制并发客户连接数最多为20个 max_per_ip=2#限制来自同一ip的客户连接数最多为2个 local_max_rate=102400#限制本地用户的最大传输速率 pasv_enable=YES#允许被动模式连接 pasv_max_port=24600#用于被动连接最大端口号 pasv_min_port=24500#用于被动连接最小端口号
我们希望laya用户可以登录ftp服务器,修改user_list文件,加入laya用户
[root@localhost~]#vim/etc/vsftpd/user_list laya
[root@localhost~]#servicevsftpdrestart
5.我在虚拟机的centos系统上安装了vsftp服务器,在本机windows系统下载一个ftp客户端FileZilla Client
看看是否能连接上,你会发现laya用户登录不上去,可能ftp服务器被防火墙或 selinux的安全机制防住了。所以必须要让防火墙通过ftp,当然也要让SELINUX通过ftp服务器才行
我们可以关掉防火墙,但出于安全考虑,我们配置一下端口
编辑/etc/sysconfig/iptables-config文件,添加以下两行:
IPTABLES_MODULES="ip_conntrack_ftp" IPTABLES_MODULES="ip_nat_ftp"
再打开/etc/sysconfig/iptables文件
[root@localhost~]#vim/etc/sysconfig/iptables -A-INPUT-ptcp-mstate--stateNEW-mtcp--dport21-jACCEPT -A-INPUT-ptcp-mstate--stateNEW-mtcp--sport21-jACCEPT -A-INPUT-Ptcp--dport20-jACCEPT
重启一下iptables服务
执行下面这条命令
[root@localhost~]#setsebool-Pftp_home_dir1