欢迎光临中国护送网
详情描述

vsftpd(最常用)和ProFTPD两种主流方案的详细步骤:

方案一:使用 vsftpd(推荐)

1. 安装 vsftpd

sudo apt update
sudo apt install vsftpd

2. 配置 vsftpd

备份原始配置文件:

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

编辑配置文件:

sudo nano /etc/vsftpd.conf

3. 常用配置选项

# 允许本地用户登录
local_enable=YES

# 允许写入操作
write_enable=YES

# 设置本地用户的umask
local_umask=022

# 允许匿名登录(可选)
anonymous_enable=NO

# 禁止匿名用户上传(如果启用匿名登录)
anon_upload_enable=NO

# 限制用户只能访问其家目录
chroot_local_user=YES
allow_writeable_chroot=YES

# 被动模式设置(适合防火墙/NAT后)
pasv_enable=YES
pasv_min_port=40000
pasv_max_port=50000
pasv_address=你的公网IP地址

# 使用SSL/TLS(可选)
ssl_enable=NO  # 如需启用SSL,设为YES并配置证书

4. 创建FTP用户

创建专用FTP用户(非登录用户):

sudo useradd -m ftpuser -s /usr/sbin/nologin
sudo passwd ftpuser

或使用现有系统用户:

# 允许现有用户登录FTP
sudo usermod -s /bin/bash 用户名

5. 启动和启用服务

sudo systemctl restart vsftpd
sudo systemctl enable vsftpd
sudo systemctl status vsftpd

6. 防火墙设置

如果使用UFW防火墙:

sudo ufw allow 20/tcp
sudo ufw allow 21/tcp
sudo ufw allow 40000:50000/tcp  # 被动模式端口范围

方案二:使用 ProFTPD

1. 安装 ProFTPD

sudo apt install proftpd

安装过程中选择:

  • Standalone:独立运行模式
  • inetd:由inetd管理(适用于低负载)

2. 基本配置

编辑主配置文件:

sudo nano /etc/proftpd/proftpd.conf

添加或修改以下内容:

ServerName "Your FTP Server"
ServerType standalone
DefaultRoot ~  # 限制用户到其家目录
RequireValidShell off  # 允许无shell用户登录

3. 创建用户

# 创建用户组
sudo groupadd ftpgroup

# 创建用户(无登录权限)
sudo useradd -g ftpgroup -d /var/ftp -s /bin/false ftpuser
sudo passwd ftpuser

# 设置目录权限
sudo chown -R ftpuser:ftpgroup /var/ftp
sudo chmod -R 755 /var/ftp

4. 启动服务

sudo systemctl restart proftpd
sudo systemctl enable proftpd

客户端连接测试

Linux/Mac客户端:

ftp 服务器IP地址
# 或使用lftp(功能更强)
lftp ftp://用户名@服务器IP地址

Windows客户端:

  • 文件资源管理器:ftp://服务器IP地址
  • 使用FileZilla、WinSCP等专业FTP客户端

安全建议

使用SFTP替代FTP(FTP传输不加密):

# SFTP已随SSH服务器自动启用
sudo apt install openssh-server

配置TLS/SSL加密(vsftpd):

sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 \
  -keyout /etc/ssl/private/vsftpd.pem -out /etc/ssl/private/vsftpd.pem

然后在配置文件中启用SSL。

限制用户访问

  • 使用 userlist_enable=YES 控制允许/拒绝的用户
  • 配置 userlist_file=/etc/vsftpd.userlist

日志监控

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

常见问题解决

连接超时:检查防火墙设置 登录失败:确认用户shell在/etc/shells无法上传文件:检查目录权限和配置中的write_enable 被动模式问题:正确配置pasv_address(公网IP)

更安全的替代方案

考虑到FTP协议的不安全性,建议考虑:

  • SFTP:基于SSH的文件传输
  • FTPS:FTP over SSL/TLS
  • rsync:增量文件同步

注意:FTP协议默认不加密,生产环境建议使用SFTP或配置SSL/TLS加密。

相关帖子
对于不熟悉技术的老人,如何为他们设置简单有效的手机防盗功能?
对于不熟悉技术的老人,如何为他们设置简单有效的手机防盗功能?
人才引进中的“柔性引才”模式,在2026年会以哪些更灵活的形式出现并应用?
人才引进中的“柔性引才”模式,在2026年会以哪些更灵活的形式出现并应用?
目前国内外有哪些值得关注的、非医疗领域的脑机接口初创公司?
目前国内外有哪些值得关注的、非医疗领域的脑机接口初创公司?
2026年,拥有多个技能证书或跨领域复合技能的人才薪酬会更占优势吗?
2026年,拥有多个技能证书或跨领域复合技能的人才薪酬会更占优势吗?
虚拟偶像与真人偶像的粉丝生态和互动模式,存在哪些根本性的不同?
虚拟偶像与真人偶像的粉丝生态和互动模式,存在哪些根本性的不同?
驻马店市120救护车出租收费标准-长途120急救车租赁护送病人返乡
驻马店市120救护车出租收费标准-长途120急救车租赁护送病人返乡
社保断缴对不同缴费档次的人群,其长期影响的差异具体体现在哪些方面?
社保断缴对不同缴费档次的人群,其长期影响的差异具体体现在哪些方面?
沧州市私人救护车长途护送病人转院-设备齐全,收费合理
沧州市私人救护车长途护送病人转院-设备齐全,收费合理
淮南市购物网站设计开发@网站运营,提供一站式建站服务
淮南市购物网站设计开发@网站运营,提供一站式建站服务
今年的认证是否对拍照或录制视频的环境、光线有更明确的要求?
今年的认证是否对拍照或录制视频的环境、光线有更明确的要求?
2026年协助办理就业困难人员社保补贴的公共就业服务机构联系方式有哪些?
2026年协助办理就业困难人员社保补贴的公共就业服务机构联系方式有哪些?
秦皇岛市救护车转运电话-接送患者转院出院
秦皇岛市救护车转运电话-接送患者转院出院
社区在临时救助工作中扮演什么角色,居民该如何向社区有效反映困难?
社区在临时救助工作中扮演什么角色,居民该如何向社区有效反映困难?
杭州市企业建站#企业网站建设,专业开发团队
杭州市企业建站#企业网站建设,专业开发团队
苏州市电商网站建设@专业网站设计,专业设计团队
苏州市电商网站建设@专业网站设计,专业设计团队
信阳市正规长途救护车出租-医疗转运车出租,24小时在线电话
信阳市正规长途救护车出租-医疗转运车出租,24小时在线电话
未来社区倡导的绿色物业服务模式,可能会对物业费构成与服务方式产生哪些影响?
未来社区倡导的绿色物业服务模式,可能会对物业费构成与服务方式产生哪些影响?
共享单车乱停乱放问题,是技术缺陷、管理失位还是用户素质的体现?
共享单车乱停乱放问题,是技术缺陷、管理失位还是用户素质的体现?
周口市病人转运租救护车-救护车转院病人返乡,收费合理
周口市病人转运租救护车-救护车转院病人返乡,收费合理
如果全面推行四天工作制,对我们的日常生活和消费模式会产生哪些连锁影响?
如果全面推行四天工作制,对我们的日常生活和消费模式会产生哪些连锁影响?