首页 帮助中心 新加坡云服务器 CentOS7 搭建vsftpd详细教程
CentOS7 搭建vsftpd详细教程
时间 : 2022-11-08 09:37:19 编辑 : 华纳云 阅读量 : 149

vsftp被公认目前最好的ftp之一,所以,搭建它还是很有意义的,有了它,我们可以让虚拟机与主机更加方便的通信。root用户,在默认的情况下,是不允许做为ftp用户登录的,但是我们可以通过一些配置,来解禁。下面正是这些操作的详细讲解,适当的时候并贴上相应的脚本。

1.安装vsftp

用yum命令查找到了我们想要的vsftpd,开始安装。

https://www.hncloud.com/uploads/UEditorImages/202211/08/bd9b6d8f2635be98435295656b8f3209.jpg

安装:yuminstall -y vsftpd

2.防火墙设置

如果防火墙把ftp的端口给拦截了,我们是无法访问到ftp服务的。我们可以选择把ftp的端口给关闭,但是个人不推荐。防火墙还是开着吧,虽然麻烦了一点。我比较喜欢用到哪个端口用开启哪个端口。

当然如果不想麻烦,也提供CentOS7中关闭防火墙的方法:

https://www.hncloud.com/uploads/UEditorImages/202211/08/d7c8ddf9dc0e40f9c3d0af8c565cce1b.jpg

如果不关闭防火墙的话,我们可以把ftp服务添加了防火墙外:

https://www.hncloud.com/uploads/UEditorImages/202211/08/ebe122da1690d1fa572f9480031e0940.jpg

3.设置SELinux

为什么要设置SELinux?

SELinux(Security-Enhanced Linux)是美国国家安全局(NSA)对于强制访问控制的实现,是 Linux历史上最杰出的新安全子系统。NSA是在Linux社区的帮助下开发了一种访问控制体系,在这种访问控制体系的限制下,进程只能访问那些在他的任务中所需要文件。

SELinux旨在提高Linux系统的安全性,提供强健的安全保证,可防御未知攻击。

大部分情况下,我们访问ftp的时候会被SELinux拦截,当然如果你没也设置SELiunx也能正常访问,此步可以跳过。

大家通常的作法是关闭SELiunx,这样做会引起其它安全问题,嫌麻烦的可以直接关闭:

https://www.hncloud.com/uploads/UEditorImages/202211/08/7e83d4f60c42f0b2ee182df19d521dca.jpg

SELiunx一共有三种模式:

1.enforcing(强制模式 ):开始限制domain/type

2.permissive(宽容模式) :仅会有警告信息

3.disabled(关闭):关闭SELinux

设置SELiunx:

https://www.hncloud.com/uploads/UEditorImages/202211/08/662e901d58f7600572196f694246c66f.jpg

setenforce <span>0</span> <span>#暂时让SELinux进入Permissive模式</span>

这个时候我们尝试访问一下ftp目录,发现能够正常访问。我们查看一下权限:

https://www.hncloud.com/uploads/UEditorImages/202211/08/ad7d0720ae4357c62a76a9894891a64e.jpg

ftp_home_dir和allow_ftpd_full_access必须为on 才能使vsftpd 具有访问ftp根目录,以及文件传输等权限。

setsebool <span>-P</span> tftp_home_dir <span>1</span>

setsebool <span>-P</span> allow_ftpd_full_access <span>1</span>

让我们再回到强制模式:

setenforce <span>1</span> <span>#进入Enforcing模式</span>

如果还是不行的话,可能是我们的目录没有权限:

chmod -R <span>777</span> /usr/yong.cao/<span>ftp</span> <span>#ftp的访问路径</span>

4.配置vsftpd

用vim /etc/vsftpd/vsftpd.conf打开后修改或者新增:

https://www.hncloud.com/uploads/UEditorImages/202211/08/116950d058ad1a0aaf36e55f7f4f47d3.jpg

5.激活root用户

处于安全考虑,root用户是不能作为ftp的登录账户的,如果在没有限制访问目录的情况下,root用户可以在ftp里访问任一文件,所以默认是不能登录ftp的。当然,你也可以为新建一些用户,专门作为ftp用户,个人习惯,用虚拟机的时候我一般直接用root用户登录ftp。

我们需要注释或者删除/etc/vsftpd/ftpusers和/etc/vsftpd/user_list中的root:

https://www.hncloud.com/uploads/UEditorImages/202211/08/5dde2c0b028ff3ebaf1993e2b415579e.jpg

6.重启服务

CentOS7中是用这个命令:

systemctl restart vsftpd<span>.service</span>

如果是其它系统:

service restart vsftpd

华纳云 推荐文章
windwos下IIS日志时间问题的解决方法 CentOS 上安装GNU编译器套件—GCC win2003 防止网卡本地连接被禁用的设置方法 Ubuntu 中安装和实用Docker Compose Windows Server 2012备份管理 Ubuntu中一键安装Notepad ++ CentOS 7 中使用 cPanel 配置 Nginx 反向代理 CentOS怎么部署redis数据库? Win2008 r2服务器配置服务器教程(图文详解) 配置IIS7显示详细错误信息
客服咨询
7*24小时技术支持
技术支持
渠道支持