在Debian上配置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
listen_ipv6=NO
# 允許本地用戶登錄
local_enable=YES
# 允許寫操作
write_enable=YES
# 啟用虛擬用戶
guest_enable=YES
guest_username=ftpuser
# 虛擬用戶的主目錄
virtual_use_local_privs=YES
local_root=/home/vsftpd/$USER
# 虛擬用戶的配置文件路徑
user_config_dir=/etc/vsftpd/user_conf
# 啟用PAM認證
pam_service_name=vsftpd
為每個虛擬主機創建一個用戶目錄:
sudo mkdir -p /home/vsftpd/vhost1
sudo mkdir -p /home/vsftpd/vhost2
創建一個虛擬用戶配置文件目錄,并為每個虛擬用戶創建一個配置文件:
sudo mkdir /etc/vsftpd/user_conf
sudo touch /etc/vsftpd/user_conf/vhost1
sudo touch /etc/vsftpd/user_conf/vhost2
編輯虛擬用戶配置文件,例如/etc/vsftpd/user_conf/vhost1:
sudo nano /etc/vsftpd/user_conf/vhost1
在文件中添加以下內容:
local_root=/home/vsftpd/vhost1
write_enable=YES
anon_upload_enable=YES
anon_mkdir_write_enable=YES
對vhost2進行類似的配置:
sudo nano /etc/vsftpd/user_conf/vhost2
內容如下:
local_root=/home/vsftpd/vhost2
write_enable=YES
anon_upload_enable=YES
anon_mkdir_write_enable=YES
使用db_load命令創建虛擬用戶數據庫:
sudo touch /etc/vsftpd/virtual_users.txt
sudo echo "vhost1" >> /etc/vsftpd/virtual_users.txt
sudo echo "vhost2" >> /etc/vsftpd/virtual_users.txt
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
編輯PAM配置文件/etc/pam.d/vsftpd:
sudo nano /etc/pam.d/vsftpd
添加以下內容:
auth required pam_userdb.so db=/etc/vsftpd/virtual_users
account required pam_userdb.so db=/etc/vsftpd/virtual_users
最后,重啟vsftpd服務以應用更改:
sudo systemctl restart vsftpd
確保防火墻允許FTP流量:
sudo ufw allow 20/tcp
sudo ufw allow 21/tcp
sudo ufw reload
完成以上步驟后,你的Debian FTP服務器應該已經配置好了虛擬主機。你可以通過FTP客戶端連接到服務器,并使用虛擬用戶名和密碼進行訪問。