欢迎光临百色市转运网
详情描述

一、安装 vsftpd

# Ubuntu/Debian
sudo apt update
sudo apt install vsftpd openssl

# CentOS/RHEL
sudo yum install vsftpd openssl

二、配置 SSL/TLS 证书

1. 创建证书目录

sudo mkdir -p /etc/ssl/private
sudo chmod 700 /etc/ssl/private

2. 生成自签名证书(生产环境建议使用正式证书)

sudo openssl req -x509 -nodes -days 3650 -newkey rsa:2048 \
  -keyout /etc/ssl/private/vsftpd.key \
  -out /etc/ssl/certs/vsftpd.crt \
  -subj "/C=CN/ST=State/L=City/O=Organization/CN=your-domain.com"

三、配置 vsftpd

1. 备份原始配置

sudo cp /etc/vsftpd.conf /etc/vsftpd.conf.backup

2. 编辑配置文件

sudo nano /etc/vsftpd.conf

3. 添加/修改以下配置

# 基本设置
listen=YES
listen_ipv6=NO
anonymous_enable=NO
local_enable=YES
write_enable=YES
dirmessage_enable=YES
use_localtime=YES
xferlog_enable=YES
connect_from_port_20=YES

# 用户限制
chroot_local_user=YES
allow_writeable_chroot=YES
user_sub_token=$USER
local_root=/home/$USER/ftp

# 被动模式设置(重要)
pasv_enable=YES
pasv_min_port=40000
pasv_max_port=50000
pasv_address=你的服务器公网IP  # 修改为你的实际IP

# SSL/TLS 配置
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/ssl/certs/vsftpd.crt
rsa_private_key_file=/etc/ssl/private/vsftpd.key

# 显式加密要求
require_ssl_reuse=NO
ssl_ciphers=HIGH

四、创建 FTP 用户

1. 创建系统用户(禁止SSH登录)

sudo useradd -m -s /bin/bash ftpuser
sudo passwd ftpuser

# 创建FTP专用目录
sudo mkdir /home/ftpuser/ftp
sudo chown ftpuser:ftpuser /home/ftpuser/ftp

2. 限制用户只能访问FTP目录

# 可选:如果需要限制用户只能访问自己的ftp目录
echo "ftpuser" | sudo tee -a /etc/vsftpd.user_list

五、配置防火墙

Ubuntu/Debian (UFW)

sudo ufw allow 21/tcp
sudo ufw allow 20/tcp
sudo ufw allow 40000:50000/tcp
sudo ufw reload

CentOS/RHEL (Firewalld)

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

六、启动服务

# 启动 vsftpd
sudo systemctl start vsftpd

# 设置开机自启
sudo systemctl enable vsftpd

# 检查状态
sudo systemctl status vsftpd

七、测试连接

使用支持显式加密的 FTP 客户端:

FileZilla 配置:

主机:你的服务器IP 端口:21 加密:显式 FTP over TLS 登录类型:正常 用户名/密码:ftpuser/你设置的密码

命令行测试:

# 安装 lftp
sudo apt install lftp

# 连接测试
lftp ftpuser@服务器IP
# 输入密码后,输入:
set ftp:ssl-force true
set ssl:verify-certificate no  # 仅测试时使用,生产环境建议验证证书
ls

八、故障排除

常见问题及解决:

连接被拒绝

# 检查服务状态
sudo systemctl status vsftpd

# 检查端口监听
sudo netstat -tlnp | grep vsftpd

SSL/TLS 握手失败

# 检查证书权限
sudo ls -l /etc/ssl/private/vsftpd.key
sudo ls -l /etc/ssl/certs/vsftpd.crt

# 查看日志
sudo tail -f /var/log/vsftpd.log

被动模式失败

# 确保防火墙开放被动端口范围
# 在配置文件中正确设置 pasv_address

九、安全建议

使用强密码策略 定期更新 SSL 证书 启用日志审计 考虑使用 SFTP(更安全)替代 FTP 限制用户访问权限 监控异常登录尝试

十、SFTP 替代方案(推荐)

如果安全性要求高,建议使用 SFTP:

# 使用 OpenSSH 内置的 SFTP
# 编辑 /etc/ssh/sshd_config
Subsystem sftp internal-sftp

Match Group sftpusers
    ChrootDirectory /home/%u
    ForceCommand internal-sftp
    AllowTcpForwarding no
    X11Forwarding no

这样配置后,用户可以通过 SSH 端口(22)使用 SFTP 协议进行安全的文件传输。

相关帖子
水管漏水导致自家和楼下损失,责任划分的法律依据是什么?
水管漏水导致自家和楼下损失,责任划分的法律依据是什么?
百色市私人救护车出租电话|救护车收费多少钱一公里
百色市私人救护车出租电话|救护车收费多少钱一公里
百色市网站定制|网站优化,高端网站开发设计
百色市网站定制|网站优化,高端网站开发设计
亲子帐篷小课堂:如何通过选帐篷、搭帐篷培养孩子的动手与协作力
亲子帐篷小课堂:如何通过选帐篷、搭帐篷培养孩子的动手与协作力
百色市救护车长途跨省转运病人|车内自带自动担架
百色市救护车长途跨省转运病人|车内自带自动担架
2026年成为工会会员,除了权益保障外,对个人社会身份认同有何影响?
2026年成为工会会员,除了权益保障外,对个人社会身份认同有何影响?
北京市救护车出院接送|120救护车租车转运病人
北京市救护车出院接送|120救护车租车转运病人
新乡市专业网站设计开发#做网站公司,一站式建站服务
新乡市专业网站设计开发#做网站公司,一站式建站服务
父母步入老年后可能对科技产品产生依赖或恐惧,成年子女应如何帮助其适应?
父母步入老年后可能对科技产品产生依赖或恐惧,成年子女应如何帮助其适应?
西藏私人长途救护车出租护送病人转院|长途救护车租车护送病人转院
西藏私人长途救护车出租护送病人转院|长途救护车租车护送病人转院
为什么说遛狗时使用牵引绳是对宠物、他人以及自己负责的首要表现?
为什么说遛狗时使用牵引绳是对宠物、他人以及自己负责的首要表现?
如何识别并应对婴幼儿成长过程中一些常见的、但令家长困惑的行为?
如何识别并应对婴幼儿成长过程中一些常见的、但令家长困惑的行为?
针对特定专业或职业路径转换者,职场中可能存在哪些先入为主的偏见?
针对特定专业或职业路径转换者,职场中可能存在哪些先入为主的偏见?
林芝市120跨省长途救护车出租|长途120急救车租赁,就近派车
林芝市120跨省长途救护车出租|长途120急救车租赁,就近派车
西宁市商城网站开发#苹果app开发,专业开发团队
西宁市商城网站开发#苹果app开发,专业开发团队
远程办公、混合工作制的普及,对地域间的“年薪”差异观念带来了哪些改变?
远程办公、混合工作制的普及,对地域间的“年薪”差异观念带来了哪些改变?
那曲市长途120救护车出租转院|急救车出租咨询电话,按公里收费
那曲市长途120救护车出租转院|急救车出租咨询电话,按公里收费
如何理解抚恤金“用于抚慰”的性质,在分配时主要考虑哪些因素?
如何理解抚恤金“用于抚慰”的性质,在分配时主要考虑哪些因素?
除了牛奶,还有哪些常见食品的包装上会合法标注“高钙”字样?
除了牛奶,还有哪些常见食品的包装上会合法标注“高钙”字样?
2026年居住证积分续办时,如果社保有短期断缴会影响最终分值吗?
2026年居住证积分续办时,如果社保有短期断缴会影响最终分值吗?