在Ubuntu上设置FTP服务器的虚拟主机,通常使用vsftpd(Very Secure FTP Daemon)作为FTP服务器软件。以下是详细的步骤:
首先,确保你的系统是最新的,然后安装vsftpd:
sudo apt update
sudo apt install vsftpd
编辑vsftpd的配置文件 /etc/vsftpd.conf
:
sudo nano /etc/vsftpd.conf
在配置文件中,找到并修改以下参数:
listen=YES
:启用vsftpd监听。listen_ipv6=NO
:禁用IPv6(如果不需要)。anonymous_enable=NO
:禁止匿名用户登录。local_enable=YES
:允许本地用户登录。write_enable=YES
:允许FTP写操作。chroot_local_user=YES
:将本地用户限制在其主目录中。allow_writeable_chroot=YES
:允许chroot目录可写(如果需要)。vsftpd本身不直接支持虚拟主机,但可以通过配置多个用户和目录来实现类似的效果。
为每个虚拟主机创建一个用户,并为其分配一个主目录:
sudo adduser user1
sudo adduser user2
为每个用户设置密码:
sudo passwd user1
sudo passwd user2
为每个用户创建一个主目录,并设置适当的权限:
sudo mkdir /home/user1
sudo mkdir /home/user2
sudo chown user1:user1 /home/user1
sudo chown user2:user2 /home/user2
sudo chmod 755 /home/user1
sudo chmod 755 /home/user2
在 /etc/vsftpd.conf
中添加以下配置,以指定每个用户的FTP访问目录:
sudo nano /etc/vsftpd.conf
添加以下行:
userlist_enable=YES
userlist_file=/etc/vsftpd.userlist
userlist_deny=NO
创建用户列表文件 /etc/vsftpd.userlist
,并添加用户名:
sudo nano /etc/vsftpd.userlist
添加用户名:
user1
user2
保存并关闭配置文件后,重启vsftpd服务以应用更改:
sudo systemctl restart vsftpd
确保防火墙允许FTP流量:
sudo ufw allow 20/tcp
sudo ufw allow 21/tcp
sudo ufw reload
使用FTP客户端连接到服务器,并测试是否可以访问相应的用户目录。
通过以上步骤,你可以在Ubuntu上设置FTP服务器的虚拟主机。每个用户将有自己的主目录,并且可以通过FTP访问这些目录。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
推荐阅读:Ubuntu FTPServer如何重启