在Ubuntu上配置vsftpd以使用虚拟用户需要经过几个步骤。以下是详细的配置过程:
首先,确保你已经安装了vsftpd。如果没有安装,可以使用以下命令进行安装:
sudo apt update
sudo apt install vsftpd
你需要创建一个虚拟用户数据库文件,并添加虚拟用户信息。
sudo touch /etc/vsftpd/virtual_users.txt
sudo chmod 600 /etc/vsftpd/virtual_users.txt
使用文本编辑器(如nano)打开 /etc/vsftpd/virtual_users.txt
文件,并添加虚拟用户信息。每行包含用户名和密码,格式如下:
username1 password1
username2 password2
保存并关闭文件。
安装 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
编辑vsftpd的配置文件 /etc/vsftpd.conf
,以启用虚拟用户并配置相关选项。
sudo nano /etc/vsftpd.conf
在文件中添加或修改以下配置项:
listen_ipv6 NO
anonymous_enable NO
local_enable YES
write_enable YES
chroot_local_user YES
allow_writeable_chroot YES
guest_enable YES
guest_username ftpuser
virtual_use_local_privs YES
user_sub_token USER
local_root /home/ftpuser
chroot_local_user YES
allow_writeable_chroot YES
确保PAM认证已启用。编辑 /etc/pam.d/vsftpd
文件,添加以下行:
auth required pam_userdb.so db=/etc/vsftpd/virtual_users
account required pam_userdb.so db=/etc/vsftpd/virtual_users
为了使虚拟用户能够访问文件系统,需要创建一个系统用户,并将其主目录设置为虚拟用户的根目录。
sudo adduser --system --home /home/ftpuser --no-create-home ftpuser
sudo usermod -d /home/ftpuser ftpuser
sudo chown -R ftpuser:ftpuser /home/ftpuser
最后,重启vsftpd服务以应用所有更改:
sudo systemctl restart vsftpd
使用FTP客户端连接到服务器,并尝试使用虚拟用户登录,以确保配置正确。
ftp 127.0.0.1
Connected to 127.0.0.1.
220 Welcome to my FTP server.
Name (127.0.0.1:ftpuser): ftpuser
331 Please specify the password.
Password:
230 Login successful.
Remote system type is UNIX.
Using binary mode to transfer files.