vsftp 配置虚拟用户+外网无法访问的原因(ftpget,1,66)

一、安装

yum install -y epel-release
yum install  -y vsftpd

二、修改配置文件

vim /etc/vsftp/vsftpd.conf
# 修改  
anonymous_enable=NO  
listen=YES
listen_ipv6=NO #或者删掉
chroot_local_user=YSE #限定用户主目录
#结尾添加
pam_service_name=visualuser
guest_enable=YES  #开启虚拟用户
guest_username=vsftpd  ##如果你是用nginx web站点这里修改nginx.conf里 user 对应的用户名 记得站点目录也要用对应的user用户
user_config_dir=/etc/vsftpd/vsftpd_user_conf
virtual_use_local_privs=YES

#被动模式可添加如下参数

pasv_promiscuous=YES 
pasv_min_port=30000   
pasv_max_port=30999
vim  /etc/pam.d/visualuser
account     required    pam_userdb.so  db=/etc/vsftpd/virtusers
auth        required    pam_userdb.so  db=/etc/vsftpd/virtusers

三、创建存储虚拟用户配置的文件夹

mkdir /etc/vsftpd/vsftpd_user_conf  -p

#创建单用户配置文件

vim  /etc/vsftpd/vsftpd_user_conf/nginx
local_root=/var/www/html
anon_umask=022   #上传的文件权限掩码 对应文件权限644 目录权限755
write_enable=YES  #是否可写
download_enable=NO  #是否可以下载
allow_writeable_chroot=YES #允许在自己目录写
anon_upload_enable=YES  #主用户是否可上传
anon_mkdir_write_enable=YES  #主用户是否可以写 
anon_other_write_enable=NO  #其他用户可写
anon_world_readable_only=YES #主用户全局可读
vim  /etc/vsftpd/ftpusers

#键盘直接输入ggdG全部删除
#添加如下参数

nginx  #用户名
nginx123 #密码

执行
db_load -T -t hash -f /etc/vsftpd/ftpusers /etc/vsftpd/virtusers.db

#centos 6

 service vsftpd start

#centos 7

systemctl start vsftpd
如果无法登陆请执行指定用户主目录
usermod  nginx  -d /var/www/html -s /sbin/nologin
如果ftp发布到外网添加下面的参数,可解决某些单片机ftp模块 opereation error的问题,如果还有问题请取消虚拟用户模式虽然不安全,后面继续寻找解决方案

在 /etc/vsftpd 中添加如下参数

pasv_addr_resolve=YES
pasv_address=www.xxx.cn #你的域名或者ip
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值