1. 安装
yum install vsftpd -y
2. 配置
vim /etc/vsftpd/vsftpd.conf
anonymous_enable=NO # 不允许匿名用户登录
local_enable=YES # 允许本地用户登录
write_enable=YES # 允许写入
local_umask=022 # 掩码为022,表示755的权限
dirmessage_enable=YES # 如果启动这个选项,那么使用者第一次进入一个目录时,会检查该目录下是否有.message这个档案,如果有,则会出现此档案的内容,通常这个档案会放置欢迎话语,或是对该目录的说明。默认值为开启。
xferlog_enable=YES #是否启用上传/下载日志记录。如果启用,则上传与下载的信息将被完整纪录在xferlog_file 所定义的档案中。预设为开启。
connect_from_port_20=YES # 指定FTP使用20端口进行数据传输,默认值为YES。
xferlog_std_format=YES # 如果启用,则日志文件将会写成xferlog的标准格式,如同wu-ftpd 一般。默认值为关闭
listen=YES # 监听IPv4 sockets
listen_ipv6=NO # 关闭ipv6
pam_service_name=vsftpd # 设置PAM使用的名称,默认值为/etc/pam.d/vsftpd。
userlist_enable=YES # 是否启用vsftpd.user_list文件
tcp_wrappers=YES # 如果启用,则vsftpd服务器会检查/etc/hosts.allow 和/etc/hosts.deny 中的设置,来决定请求连接的主机,是否允许访问该FTP服务器
use_localtime=YES # vsftpd将显示当前时区中包含时间的目录列表
port_enable=YES # 如果为NO,则表示禁止用PORT方法获取数据连接
#本地用户管理
chroot_local_user=YES # 全部用户被限制在根目录
chroot_list_enable=NO # 启用例外用户名单,例外名单不锁定根目录。no没有例外用户
chroot_list_file=/etc/vsftpd/chroot_list # 指定例外用户列表文件,列表中的用户不被锁定在主目录
allow_writeable_chroot=YES # 允许写入
local_root=/home/ftptest # 设置本地用户登录后所在的目录,设置用户要与登录用户权限一直
3. 添加本地用户
useradd ftpuser
passwd ftpuser
chown -R ftpuser:ftpuser /home/ftptest
4. 启动
systemctyl restart vsftpd
5. 登录上传文件即可
image.png5. 问题解决
测试通过 ftp 命令
yum install ftp -y
ftp host #根据报错来判断是否可以访问
1、500报错
大概率是文件夹的权限不对,看看父目录是否有700权限。这种会导致无法获取到目录信息
网友评论