温馨提示×

VSFTP在CentOS上的虚拟主机配置

小樊
57
2025-06-18 06:45:17
栏目: 云计算

在CentOS上配置VSFTPD以支持虚拟主机,可以让你在同一台服务器上托管多个FTP站点。以下是一个基本的步骤指南:

1. 安装VSFTPD

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

sudo yum install vsftpd

2. 配置VSFTPD

编辑VSFTPD的主配置文件 /etc/vsftpd/vsftpd.conf

sudo vi /etc/vsftpd/vsftpd.conf

确保以下配置项被正确设置:

listen=YES
listen_ipv6=NO
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
userlist_enable=YES
tcp_wrappers=YES

3. 创建虚拟主机目录

为每个虚拟主机创建一个目录,并设置适当的权限:

sudo mkdir -p /home/vhost1
sudo mkdir -p /home/vhost2
sudo chown -R ftpuser:ftpuser /home/vhost1
sudo chown -R ftpuser:ftpuser /home/vhost2

ftpuser 替换为你选择的FTP用户名。

4. 配置用户和虚拟主机

编辑 /etc/passwd 文件,添加FTP用户:

sudo vi /etc/passwd

添加以下行:

ftpuser:x:1001:1001::/home/vhost1:/sbin/nologin
ftpuser2:x:1002:1002::/home/vhost2:/sbin/nologin

5. 配置虚拟主机配置文件

创建虚拟主机配置文件 /etc/vsftpd/vhost.conf

sudo vi /etc/vsftpd/vhost.conf

添加以下内容:

listen_port=21
listen_ip=127.0.0.1
local_root=/home/vhost1
userlist_enable=YES
userlist_file=/etc/vsftpd/user_list
userlist_deny=NO

为第二个虚拟主机创建另一个配置文件 /etc/vsftpd/vhost2.conf

listen_port=21
listen_ip=127.0.0.1
local_root=/home/vhost2
userlist_enable=YES
userlist_file=/etc/vsftpd/user_list
userlist_deny=NO

6. 启动和启用VSFTPD服务

启动VSFTPD服务并设置为开机自启:

sudo systemctl start vsftpd
sudo systemctl enable vsftpd

7. 配置防火墙

确保防火墙允许FTP流量:

sudo firewall-cmd --permanent --add-port=21/tcp
sudo firewall-cmd --reload

8. 测试配置

使用FTP客户端连接到服务器,测试虚拟主机配置是否正确。

通过以上步骤,你应该能够在CentOS上成功配置VSFTPD以支持虚拟主机。如果有任何问题,请检查日志文件 /var/log/vsftpd.log 以获取更多信息。

0