ubuntu

Ubuntu vsftp虚拟用户配置

小樊
35
2025-06-11 04:12:34
栏目: 云计算

在Ubuntu上配置vsftpd以使用虚拟用户需要经过几个步骤。以下是详细的配置过程:

1. 安装vsftpd

首先,确保你已经安装了vsftpd。如果没有安装,可以使用以下命令进行安装:

sudo apt update
sudo apt install vsftpd

2. 创建虚拟用户数据库

你需要创建一个虚拟用户数据库文件,并添加虚拟用户信息。

创建虚拟用户数据库文件

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

3. 配置vsftpd

编辑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

4. 配置PAM认证

确保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

5. 创建系统用户

为了使虚拟用户能够访问文件系统,需要创建一个系统用户,并将其主目录设置为虚拟用户的根目录。

sudo adduser --system --home /home/ftpuser --no-create-home ftpuser
sudo usermod -d /home/ftpuser ftpuser
sudo chown -R ftpuser:ftpuser /home/ftpuser

6. 重启vsftpd服务

最后,重启vsftpd服务以应用所有更改:

sudo systemctl restart vsftpd

7. 测试配置

使用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.

0
看了该问题的人还看了