ubuntu

如何在Ubuntu上配置vsftp虚拟用户

小樊
36
2025-03-12 10:01:04
栏目: 云计算

在Ubuntu上配置vsftpd虚拟用户需要以下几个步骤:

  1. 安装vsftpd: 打开终端,运行以下命令来安装vsftpd:

    sudo apt-get update
    sudo apt-get install vsftpd
    
  2. 创建虚拟用户数据库: 首先,创建一个文件来存储虚拟用户的用户名和密码。例如,创建一个名为/etc/vsftpd/virtual_users.txt的文件:

    sudo touch /etc/vsftpd/virtual_users.txt
    sudo chmod 600 /etc/vsftpd/virtual_users.txt
    

    然后,使用文本编辑器打开文件,并添加虚拟用户的用户名和密码。每行一个用户,格式为用户名:密码。例如:

    user1
    password1
    user2
    password2
    
  3. 创建虚拟用户映射: 安装db-util工具来生成虚拟用户映射数据库:

    sudo apt-get install db-util
    

    使用db_load命令创建虚拟用户映射数据库:

    sudo db_load -T -t hash -f /etc/vsftpd/virtual_users.txt /etc/vsftpd/virtual_users.db
    sudo chmod 600 /etc/vsftpd/virtual_users.db
    
  4. 配置vsftpd: 使用文本编辑器打开/etc/vsftpd.conf文件:

    sudo nano /etc/vsftpd.conf
    

    修改以下配置项:

    • anonymous_enable=YES改为anonymous_enable=NO,禁止匿名用户登录。
    • 取消local_enable=YES的注释,允许本地用户登录。
    • 取消write_enable=YES的注释,允许FTP写操作。
    • 添加以下配置项以启用虚拟用户:
      guest_enable=YES
      guest_username=ftp
      virtual_use_local_privs=YES
      user_sub_token=$USER
      local_root=/home/$USER
      chroot_local_user=YES
      allow_writeable_chroot=YES
      
    • 添加以下配置项以使用虚拟用户映射数据库:
      pam_service_name=vsftpd-virtual
      userlist_enable=YES
      tcp_wrappers=YES
      

    保存并关闭文件。

  5. 配置PAM(可插拔认证模块): 创建一个名为/etc/pam.d/vsftpd-virtual的文件:

    sudo touch /etc/pam.d/vsftpd-virtual
    sudo chmod 600 /etc/pam.d/vsftpd-virtual
    

    使用文本编辑器打开文件,并添加以下内容:

    auth required pam_userdb.so db=/etc/vsftpd/virtual_users
    account required pam_userdb.so db=/etc/vsftpd/virtual_users
    
  6. 重启vsftpd服务:

    sudo systemctl restart vsftpd
    

现在,您已经成功配置了vsftpd虚拟用户。您可以使用创建的虚拟用户名和密码登录FTP服务器。

0
看了该问题的人还看了