centos sftp如何配置虚拟用户

202
2025/3/25 18:32:31
栏目: 云计算
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

在CentOS系统中配置SFTP虚拟用户,可以按照以下步骤进行:

1. 安装必要的软件包

首先,确保你已经安装了vsftpdpam相关的软件包。

sudo yum install vsftpd pam

2. 创建虚拟用户数据库

使用db_load工具创建一个虚拟用户数据库文件。

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

3. 创建虚拟用户

创建一个虚拟用户,并将其添加到虚拟用户数据库中。

sudo useradd -d /home/vsftpd -s /sbin/nologin virtualuser
sudo passwd virtualuser

输入并确认虚拟用户的密码。

4. 配置PAM

编辑/etc/pam.d/vsftpd文件,添加以下内容以启用PAM认证。

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

5. 配置vsftpd

编辑/etc/vsftpd/vsftpd.conf文件,确保以下配置项正确设置:

listen=YES
anonymous_enable=NO
local_enable=YES
write_enable=YES
local_umask=022
dirmessage_enable=YES
use_localtime=YES
xferlog_enable=YES
connect_from_port_20=YES
chroot_local_user=YES
secure_chroot_dir=/var/run/vsftpd/empty
pam_service_name=vsftpd
guest_enable=YES
guest_username=virtualuser
virtual_use_local_privs=YES
user_sub_token=$USER
local_root=/home/vsftpd/$USER
chroot_list_enable=YES
chroot_list_file=/etc/vsftpd/chroot_list

6. 创建chroot目录

创建chroot目录并设置权限。

sudo mkdir -p /home/vsftpd/virtualuser
sudo chown root:root /home/vsftpd/virtualuser
sudo chmod 755 /home/vsftpd/virtualuser

7. 重启vsftpd服务

重启vsftpd服务以应用配置更改。

sudo systemctl restart vsftpd

8. 测试SFTP连接

使用SFTP客户端连接到服务器,测试虚拟用户的登录和文件传输功能。

sftp virtualuser@your_server_ip

输入密码后,你应该能够成功登录并进行文件传输。

注意事项

  • 确保防火墙允许SFTP连接(默认端口22)。
  • 如果使用SELinux,可能需要调整SELinux策略以允许vsftpd访问虚拟用户目录。

通过以上步骤,你应该能够在CentOS系统上成功配置SFTP虚拟用户。

辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读: GCC在CentOS中的默认编译选项是什么