Linux搭建FTP服务器 vsftpd配置教程
时间:2026-05-25 10:32:14 230浏览 收藏
本文详细介绍了在Linux系统中使用vsftpd搭建安全、可靠的FTP服务器的完整实践流程,涵盖从安装(适配yum/dnf/apt不同包管理器)、服务启停与状态验证、防火墙端口放行,到核心配置文件修改(启用本地用户写入、禁用匿名访问、配置chroot锁定)、创建专用nologin FTP用户并严格限制其访问范围,最后重启服务生效等六大关键步骤,手把手引导读者快速部署一个既满足文件上传下载需求又兼顾系统安全性的生产级FTP服务。

如果您希望在Linux系统中提供文件上传和下载服务,则需要搭建一个FTP服务器。vsftpd(Very Secure FTP Daemon)是Linux下常用、安全且轻量的FTP服务软件。以下是基于vsftpd的安装与配置步骤:
一、安装vsftpd软件包
vsftpd通常未预装在主流Linux发行版中,需通过包管理器下载并安装。不同系统使用不同的命令工具,确保以root权限执行。
1、在CentOS/RHEL 7/8系统中,运行:yum install -y vsftpd
2、在CentOS/RHEL 9或Fedora系统中,运行:dnf install -y vsftpd
3、在Ubuntu/Debian系统中,运行:apt update && apt install -y vsftpd
二、启用并启动vsftpd服务
安装完成后需启用开机自启,并立即启动服务进程,使FTP监听端口(默认21)开始接受连接请求。
1、启用服务开机自启:systemctl enable vsftpd
2、立即启动服务:systemctl start vsftpd
3、检查服务运行状态:systemctl status vsftpd,确认显示“active (running)”
三、配置防火墙放行FTP端口
Linux主机若启用firewalld或ufw,将默认拦截外部对21端口的访问,必须手动添加规则允许FTP流量通过。
1、在firewalld管理的系统中,执行:firewall-cmd --permanent --add-service=ftp
2、重载防火墙配置:firewall-cmd --reload
3、在UFW管理的Ubuntu系统中,执行:ufw allow 21,并确保UFW处于启用状态
四、修改主配置文件vsftpd.conf
vsftpd的核心行为由/etc/vsftpd/vsftpd.conf控制。为支持本地用户登录并写入文件,需调整关键参数。
1、备份原始配置:cp /etc/vsftpd/vsftpd.conf /etc/vsftpd/vsftpd.conf.bak
2、编辑配置文件:nano /etc/vsftpd/vsftpd.conf
3、确认以下行未被注释且值正确:anonymous_enable=NO、local_enable=YES、write_enable=YES、chroot_local_user=YES
五、创建专用FTP用户并限制目录
为保障系统安全,不建议直接使用root或已有用户登录FTP;应新建用户并将其根目录锁定在其家目录内,防止越权访问。
1、新增用户并禁用shell登录:useradd -m -s /sbin/nologin ftpuser
2、为其设置密码:passwd ftpuser
3、设置该用户家目录权限(vsftpd要求chroot用户目录不可有写权限):chmod a-w /home/ftpuser
4、在其家目录下创建可写子目录:mkdir /home/ftpuser/upload && chmod 755 /home/ftpuser/upload
六、重启vsftpd使配置生效
所有配置变更完成后,必须重启服务才能加载新设置,否则客户端仍可能遭遇拒绝连接或登录失败。
1、停止当前服务:systemctl stop vsftpd
2、重新加载配置并启动:systemctl restart vsftpd
3、验证端口监听状态:ss -tlnp | grep :21,确认vsftpd进程绑定在0.0.0.0:21或:::21
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Linux搭建FTP服务器 vsftpd配置教程》文章吧,也可关注golang学习网公众号了解相关技术文章。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
230 收藏
-
467 收藏
-
393 收藏
-
189 收藏
-
246 收藏
-
186 收藏
-
417 收藏
-
356 收藏
-
147 收藏
-
339 收藏
-
341 收藏
-
335 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习