在Debian系统下,为vsftpd设置虚拟用户需要遵循以下步骤:
-
安装vsftpd: 在终端中运行以下命令以安装vsftpd:
sudo apt-get update sudo apt-get install vsftpd
-
创建虚拟用户数据库: 首先,安装
db-util
软件包,它将用于创建虚拟用户数据库:sudo apt-get install db-util
接下来,创建一个名为
/etc/vsftpd/virtual_users.txt
的文件,用于存储虚拟用户的用户名和密码。例如:user1 password1 user2 password2
然后,使用
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
-
创建PAM配置文件: 在
/etc/pam.d/
目录下创建一个名为vsftpd-virtual
的文件,用于配置PAM(可插拔认证模块):sudo nano /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
-
修改vsftpd配置文件: 使用文本编辑器打开
/etc/vsftpd.conf
文件:sudo nano /etc/vsftpd.conf
找到并修改以下配置项:
local_enable=YES chroot_local_user=YES guest_enable=YES user_sub_token=$USER local_root=/home/$USER virtual_use_local_privs=YES
如果需要,还可以设置虚拟用户的根目录和其他权限。
-
重启vsftpd服务: 保存并关闭配置文件后,重启vsftpd服务以应用更改:
sudo systemctl restart vsftpd
现在,您已经成功为Debian系统下的vsftpd设置了虚拟用户。请注意,这些虚拟用户没有实际的系统账户,因此无法使用SSH登录。他们只能通过FTP访问服务器。