温馨提示×

centos上vsftp虚拟用户怎么设置

小樊
42
2025-10-06 21:34:55
栏目: 云计算

在CentOS上设置VSFTP虚拟用户,可以按照以下步骤进行:

1. 安装VSFTP

首先,确保你的CentOS系统上已经安装了VSFTP。如果没有安装,可以使用以下命令进行安装:

sudo yum install vsftpd

2. 配置VSFTP

编辑VSFTP的配置文件 /etc/vsftpd/vsftpd.conf

sudo vi /etc/vsftpd/vsftpd.conf

在配置文件中进行以下修改:

  • 启用虚拟用户:

    guest_enable=YES
    guest_username=ftpuser
    
  • 设置虚拟用户的根目录:

    local_root=/home/vsftpd/$USER
    
  • 允许虚拟用户登录:

    chroot_local_user=YES
    allow_writeable_chroot=YES
    
  • 禁止匿名用户登录:

    anonymous_enable=NO
    
  • 启用虚拟用户认证:

    pam_service_name=vsftpd
    userlist_enable=YES
    tcp_wrappers=YES
    

3. 创建虚拟用户数据库

使用 db_load 命令创建一个虚拟用户数据库文件:

sudo touch /etc/vsftpd/virtusers.txt
sudo db_load -T -t hash -f /etc/vsftpd/virtusers.txt /etc/vsftpd/virtusers.db

4. 创建PAM配置文件

创建一个PAM配置文件 /etc/pam.d/vsftpd

sudo vi /etc/pam.d/vsftpd

添加以下内容:

auth required pam_userdb.so db=/etc/vsftpd/virtusers
account required pam_userdb.so db=/etc/vsftpd/virtusers

5. 创建虚拟用户目录

为每个虚拟用户创建一个目录:

sudo mkdir -p /home/vsftpd/virtuser1
sudo chown ftpuser:ftpuser /home/vsftpd/virtuser1
sudo chmod 755 /home/vsftpd/virtuser1

6. 重启VSFTP服务

最后,重启VSFTP服务以应用更改:

sudo systemctl restart vsftpd

7. 测试虚拟用户登录

使用FTP客户端(如FileZilla)测试虚拟用户登录:

  • 主机名:你的服务器IP地址
  • 用户名:virtuser1
  • 密码:你在 /etc/vsftpd/virtusers.txt 文件中设置的密码

注意事项

  • 确保 /etc/vsftpd/virtusers.txt 文件的格式正确,每行一个用户,格式为 username:password
  • 确保 /etc/pam.d/vsftpd 文件的权限正确,通常应该是 644

通过以上步骤,你应该能够在CentOS上成功设置VSFTP虚拟用户。

0