在CentOS上配置VSFTPD以支持虚拟主机,可以让你在同一台服务器上托管多个FTP站点。以下是一个基本的步骤指南:
首先,确保你已经安装了VSFTPD。如果没有安装,可以使用以下命令进行安装:
sudo yum install 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
为每个虚拟主机创建一个目录,并设置适当的权限:
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用户名。
编辑 /etc/passwd 文件,添加FTP用户:
sudo vi /etc/passwd
添加以下行:
ftpuser:x:1001:1001::/home/vhost1:/sbin/nologin
ftpuser2:x:1002:1002::/home/vhost2:/sbin/nologin
创建虚拟主机配置文件 /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
启动VSFTPD服务并设置为开机自启:
sudo systemctl start vsftpd
sudo systemctl enable vsftpd
确保防火墙允许FTP流量:
sudo firewall-cmd --permanent --add-port=21/tcp
sudo firewall-cmd --reload
使用FTP客户端连接到服务器,测试虚拟主机配置是否正确。
通过以上步骤,你应该能够在CentOS上成功配置VSFTPD以支持虚拟主机。如果有任何问题,请检查日志文件 /var/log/vsftpd.log 以获取更多信息。