在Linux FTP服務器上啟用SSL加密,通常需要以下幾個步驟:
首先,你需要一個SSL證書。你可以從Let’s Encrypt免費獲取,或者購買一個商業證書。
安裝Certbot:
sudo apt update
sudo apt install certbot
獲取證書:
sudo certbot certonly --standalone -d yourdomain.com
按照提示完成證書的獲取和安裝。
假設你使用的是vsftpd
作為FTP服務器。
sudo apt update
sudo apt install vsftpd
編輯vsftpd配置文件:
sudo nano /etc/vsftpd.conf
啟用SSL: 找到并修改以下行:
ssl_enable=YES
allow_anon_ssl=NO
force_local_data_ssl=YES
force_local_logins_ssl=YES
ssl_tlsv1=YES
ssl_sslv2=NO
ssl_sslv3=NO
rsa_cert_file=/etc/letsencrypt/live/yourdomain.com/fullchain.pem
rsa_private_key_file=/etc/letsencrypt/live/yourdomain.com/privkey.pem
重啟vsftpd服務:
sudo systemctl restart vsftpd
確保你的防火墻允許FTP流量。
sudo ufw allow 21/tcp
sudo ufw allow 990/tcp # FTPS數據連接
sudo ufw reload
你可以使用FTP客戶端(如FileZilla)來測試SSL連接。
如果你需要配置被動模式(PASV),可以在vsftpd.conf
中添加以下配置:
pasv_enable=YES
pasv_min_port=1024
pasv_max_port=1048
然后重啟vsftpd服務:
sudo systemctl restart vsftpd
為了安全起見,你可以配置chroot jail來限制用戶的訪問權限。
編輯vsftpd.conf
:
sudo nano /etc/vsftpd.conf
添加或修改以下行:
chroot_local_user=YES
allow_writeable_chroot=YES
重啟vsftpd服務:
sudo systemctl restart vsftpd
通過以上步驟,你應該能夠在Linux FTP服務器上成功啟用SSL加密。