2021.2.20 更新
1 概述
文章核心:
CentOS8
使用vsftpd
搭建FTP
服务器- 安装以及测试的详细过程
2 安装
2.1 安装vsftpd
+ftp
sudo yum install -y vsftpd
sudo yum install -y ftp # 测试使用,搭建FTP服务器只需要vsftpd
2.2 开启服务
systemctl start vsftpd
2.3 设置开机启动(可选)
可以用
systemctl list-unit-files | grep vsftpd
查看是否开机启动,笔者机器上显示disabled
:
通过
chkconfig vsftpd on
开启自启,再次执行systemctl
,可以看到变成了enabled
。
2.4 修改配置文件
配置文件默认为/etc/vsftpd/vsftpd.conf
:
sudo vim /etc/vsftpd/vsftpd.conf
首先修改anonymouse enable=YES
,再添加一行anon_upload_enable=YES
:
第一行的意思是允许匿名登录,第二行的意思是允许匿名上传,接着重启服务:
systemctl restart vsftpd
3 测试准备
安装部分就算完成了,下面是测试。测试分为:
- 浏览器测试
ftp
命令测试
而为了测试权限,两者又分为:
- 匿名测试
- 用户登录测试
另外为了测试的完整还加入了wget
的下载测试。
在测试之前先创建测试文件:
cd /var/ftp/pub
sudo vim test
4 浏览器测试
4.1 匿名测试
ifconfig
获取内网ip
,在浏览器中输入ftp://ip
:
可以看到有一个pub
文件夹,里面有刚才新建的test
文件:
右键保存即可下载文件:
下载完成。
去终端看看:
4.2 用户登录测试
输入
ftp://username@ip
再输入用户密码即可登录成功。默认访问的是用户根目录下的文件:
下载的话同上,右键选择下载即可。
5 ftp
命令测试
首先安装ftp
:
5.1 匿名测试
ftp ip
ftp
为默认的匿名登录用户名,至于密码,可以在/etc/vsftpd/vsftpd.conf
中设置一个
no_anon_password=YES
这样匿名用户可以空密码登录。
5.1.1 上传测试
直接使用put
命令,后面接上文件,这里的upload.txt
是执行ftp
之前的所在文件夹下的upload.txt
:
这里提示不能创建文件,是权限的原因,要确保/var/ftp/pub
对other
用户有写权限:
默认的/var/ftp/pub
的权限是644
,修改成647
:
sudo chmod 647 /var/ftp/pub
同时修改上传文件的权限,允许other
用户可读:
sudo chmod 644 /root/upload.txt
如果不行,可以使用selinux
设置ftpd_full_access
:
getsebool -a | grep ftp
把ftpd_full_access
开启:
setsebool ftpd_full_access on
再进入upload.txt
所在的文件夹,执行ftp
,再次put
:
成功!
5.1.2 下载测试
直接get
文件即可,由于上面已经设置好了权限,所以不会出现问题。
若出现权限问题可从三方面入手:
/var/ftp/pub
的对other
用户的可读权限:因为是下载,而且匿名,所以只需要对other
用户的可读权限- 被下载文件的对
other
用户的可读权限 selinux
的问题,设置ftpd_full_access
为on
5.2 用户登录测试
执行ftp
时用对应用户名与密码登录:
默认进入了用户根目录。
5.2.1 上传测试
直接put
即可:
若出现权限问题参照上面5.1.2
的那三种方法。
5.2.2 下载测试
随便在用户根目录新建一个文件,这里是kr:
直接get
即可:
6 wget
测试
wget
用来下载文件,初始下载的目录与ftp
登录时的目录一致:
- 匿名登录
ftp
,登录的是/var/ftp
目录,则wget
会从这个/var/ftp
目录下载文件,下载到执行wget
命令所在的目录 - 使用用户kr登录
ftp
,则登录的是/home/kr
目录,wget
会从/home/kr
下载文件
6.1 匿名测试
注意,请确保被下载文件对other
用户有可读权限:
sudo chmod o+w xxxxxx
然后使用wget
:
wget ftp://ip/pub/xxxx
6.2 用户登录测试
使用--ftp-user
,--ftp-password
指定用户名与密码,其余同上:
wget ftp://ip/xxx --ftp-user=xxxx --ftp-password=xxxx
成功。
7 总结
总结一下步骤:
- 安装好
ftp
与vsftpd
- 修改配置文件(
/etc/vsftpd/vsftpd.conf
) - 添加对操作的文件的相应权限
对于不能上传与下载的原因,基本上都是权限的问题,主要就是三方面:
ftp
目录的权限:比如可以是/var/ftp/pub
没有对应的写权限导致上传失败,没有对应读权限导致下载失败- 被上传文件的权限:比如被上传的文件没有读权限导致上传失败
selinux
:使用setsebool
设置ftpd_full_access
为on
解决权限问题后,基本就可以通过ftp
/wget
顺利地使用这个ftp
服务器上传/下载文件了。
8 还有疑问?
可以在评论留言大家一起讨论。