目录
ftp与sftp
- 差异非常大
- ftp相当于一种网络协议,可运行在不同操作系统,默认使用21端口和20端口,明文传输且不稳定
- sftp基于ssh,默认使用22端口,Linux自带,加密传输且稳定
- vsftpd是用于配置ftp,与sftp无关
- sftp无需配置,相当于ssh远程连接,本地用户使用
sftp [email protected]即可
安装vsftpd和ftp
- ftp用于测试
yum install-y vsftpd* ftp* - 启动
systemctl start vsftpd - 防火墙开放21端口
firewall-cmd --zone=public --add-port=21/tcp --permanentfirewall-cmd --reloadfirewall-cmd --zone=public --list-ports - 测试
systemctl status vsftpdnetstat-ntlp|grep vsftpdftp XX.XX.XX.XX默认配置下,匿名用户登录,密码为空
本地用户登录-不限制访问目录
不可匿名登录
禁止其他用户访问
仅本地用户ftpuser可访问
默认访问目录/home/ftpuser
可访问其他目录
- 新增本地用户
ftpuser``````useradd-d /home/ftpuser -s /bin/bash ftpuserpasswd ftpuser - 修改配置
/etc/vsftpd/vsftpd.conf默认配置如下anonymous_enable=YESlocal_enable=YESwrite_enable=YESlocal_umask=022dirmessage_enable=YESxferlog_enable=YESconnect_from_port_20=YESxferlog_std_format=YESlisten=NOlisten_ipv6=YESpam_service_name=vsftpduserlist_enable=YEStcp_wrappers=YES修改后anonymous_enable=NO #禁止匿名用户登录服务器local_enable=YES #允许本地用户登录服务器write_enable=YES #允许写操作local_umask=022 dirmessage_enable=YESxferlog_enable=YESconnect_from_port_20=YESxferlog_std_format=YESlisten=NOlisten_ipv6=YESpam_service_name=vsftpduserlist_enable=YEStcp_wrappers=YES# YES,user_list用户为黑名单,禁止登录;NO则为白名单,可登录userlist_deny=YES# chroot_list本地用户可登录ftp名单,且本地用户需要在/etc/shells范围内或者修改/etc/pam.d/vsftpd的pam限制chroot_list_enable=YESchroot_list_file=/etc/vsftpd/chroot_list# 设置根目录可写allow_writeable_chroot=YES - 在
/etc/vsftpd/下新建chroot_list文件,然后写入本地用户ftpuser,一行代表一个用户 - 重启
systemctl restart vsftpd - 本机测试
ftp XX.XX.XX.XX成功
本地用户登录-限制访问目录
不可匿名登录
禁止其他用户访问
仅本地用户ftptest可访问
仅可访问目录/var/ftp
- 新增本地用户
ftptest``````useradd-d /var/ftp -s /sbin/nologin ftptestpasswd ftptestchmod-R777 /var/ftp - 修改
/etc/pam.d/vsftpd,使用户可通过pam验证[root@localhost vsftpd]# vi /etc/pam.d/vsftpd#%PAM-1.0 session optional pam_keyinit.so force revoke auth required pam_listfile.so item=user sense=deny file=/etc/vsftpd/ftpusers onerr=succeed #auth required pam_shells.so auth include password-auth account include password-auth session required pam_loginuid.so session include password-auth - 修改配置
anonymous_enable=NO #禁止匿名用户登录服务器local_enable=YES #允许本地用户登录服务器write_enable=YES #允许写操作local_umask=022dirmessage_enable=YESxferlog_enable=YESconnect_from_port_20=YESxferlog_std_format=YESlisten=NOlisten_ipv6=YESpam_service_name=vsftpduserlist_enable=YEStcp_wrappers=YES# YES,user_list用户为黑名单,禁止登录;NO则为白名单,可登录userlist_deny=YES# 限制访问目录本地用户仅可访问/var/ftpchroot_local_user=YESlocal_root=/var/ftp# 设置根目录可写allow_writeable_chroot=YES - 重启
systemctl restart vsftpd - 本机测试
ftp XX.XX.XX.XX成功
有可能影响连接的问题
pam认证
可根据情况注释
auth required pam_shells.so: 仅允许用户的shell是 /etc/shells文件内的shell,才能登录auth required pam_listfile.so:/etc/ftpusers 中的用户禁止登陆
# cat /etc/pam.d/vsftpd#%PAM-1.0
session optional pam_keyinit.so force revoke
auth required pam_listfile.so item=user sense=deny file=/etc/vsftpd/ftpusers onerr=succeed
auth required pam_shells.so
auth include password-auth
account include password-auth
session required pam_loginuid.so
session include password-auth
selinux策略
安全增强模块,根据情况修改
ftpd_full_access:影响创建新目录等tftp_home_dir:影响ftp根目录访问等
setsebool -P tftp_home_dir 1
setsebool -P ftpd_full_access 1
systemctl restart vsftpd
# sestatus -b | grep ftp
ftpd_anon_write off
ftpd_connect_all_unreserved off
ftpd_connect_db off
ftpd_full_access on
ftpd_use_cifs off
ftpd_use_fusefs off
ftpd_use_nfs off
ftpd_use_passive_mode off
httpd_can_connect_ftp off
httpd_enable_ftp_server off
tftp_anon_write off
tftp_home_dir on
被动模式
pasv_enable=YES
pasv_min_port=31000pasv_max_port=31999
防火墙
firewall-cmd --zone=public --add-port=31000-31999/tcp --permanent
firewall-cmd --reload
firewall-cmd --zone=public --list-ports
ipv4和ipv6
默认ipv6,可修改为ipv4配置
listen=YES
listen_ipv6=NO
报错
1、 530 Login incorrect
- 确认用户账密无误
- 网上的
pam_service_name=vsftpd方法无效 - 查看
/etc/pam.d/vsftpd文件,对以下两条要求进行排查,我的用户是/sbin/nologin,不在/etc/shells范围内。> > - auth required pam_shells.so: 仅允许用户的shell是 /etc/shells文件内的shell,才能登录> - auth required pam_listfile.so item=user sense=deny file=/etc/ftpusers onerr=succeed:/etc/ftpusers 中的用户禁止登陆[root@localhost vsftpd]# cat /etc/pam.d/vsftpd#%PAM-1.0session optional pam_keyinit.so force revokeauth required pam_listfile.so item=user sense=deny file=/etc/vsftpd/ftpusers onerr=succeedauth required pam_shells.soauth include password-authaccount include password-authsession required pam_loginuid.sosession include password-auth[root@localhost vsftpd]# cat /etc/shells/bin/sh/bin/bash/usr/bin/sh/usr/bin/bash- 方案一:可以修改/etc/pam.d/vsftpd注释掉auth required pam_shells.so- 方案二:修改用户登录属性,usermod -s /bin/bash ftptest - 重启验证,该报错解决,但登录时出现先报错
500 OOPS: vsftpd: refusing to run with writable root inside chroot(),见下条
2、500 OOPS: vsftpd: refusing to run with writable root inside chroot()
原因:安装的最新版本,增加了对配置错误的强制检查,要求根目录不可写
Add stronger checks for the configuration error of running with a
writeable root directory inside a chroot(). This may bite people who
carelessly turned on chroot_local_user but such is life.
- 方案一:配置文件设置
allow_writeable_chroot=YES - 方案二:设置
ftptest用户根目录不可写chmod a-w ftptest
3、227 Entering Passive Mode (10,1,58,5,242,166). ftp: connect: 没有到主机的路由
描述:本机ftp测试没问题;内网其他服务器ftp登陆成功,但执行ls等命令报错
原因:被动模式端口问题
- 方案一:登录后,输入
passive,关掉被动模式ftp> passivePassive mode off.ftp>ls200 PORT command successful. Consider using PASV.150 Here comes the directory listing.drwxrwxrwx 2006 Jun 09 2021 pubdrwxr-xr-x 2100110016 Feb 20 06:05 test226 Directory send OK. - 方案二:配置文件设置被动模式,并开放防火墙端口
31000-31999配置pasv_enable=YESpasv_min_port=31000pasv_max_port=31999防火墙firewall-cmd --zone=public --add-port=31000-31999/tcp --permanentfirewall-cmd --reloadfirewall-cmd --zone=public --list-ports
4、425 Failed to establish connection. Error EElFTPSError: Control channel transfer error 114690
描述:内网正常,外网登陆成功但执行其他命令失败
原因:防火墙添加端口后,未
firewall-cmd --reload
使其生效
版权归原作者 lorogy 所有, 如有侵权,请联系我们删除。