VSFTP是一个基于GPL发布的类Unix系统上使用的软件,它的全称是Very Secure FTP 从此名称可以看出来,编制者的初衷是代码的安全。它是一个安全、高速、稳定的FTP服务器。vsftpd有三种模式。匿名模式。用户模式,还有虚拟用户模式。我们分别来配置一下这几种模式。

yum install vsftpd -y           #安装

systemctl restart vsftpd        #重启

systemctl stop firewalld        #关闭防火墙(后面实验成功后再开启)

匿名用户:

默认情况下,vsftpd的匿名用户是打开的,客户端是可以访问的。

客户端访问:OK(输入ftp://ftp服务器IP地址)

默认是没有权限写入的。我们去主配置文件配置写入权限吧。

vim /etc/vsftpd/vsftpd.conf   #打开主配置文件,添加如下内容,注意不要与文中重叠

解释:

anonymous_enable=yes#允许匿名访问模式

anon_upload_enable=yes#允许匿名用户上传文件

anon_mkdir_write_enable=yes#允许匿名用户创建目录

anon_other_write_enable=yes#允许匿名用户修改目录名和删除目录

anon_world_readable_only=no#允许匿名用户下载可阅读文件(默认yes,拒绝)

chown ftp /var/ftp/pub                  #修改属主为ftp

ls -ld /var/ftp/pub                     #查看权限/var/ftp/pub默认为ftp匿名路径

getsebool -a | grep ftp#查看所有与ftp相关的SELinux规则

setsebool -P ftpd_full_access=on#设置SELinux服务队ftp服务访问规则策略为允许

注意:(这里可以先不管,暂时关闭命令  setenforce 0  )

systemctl restart vsftpd        #重启

客户端测试OK(有读取权限)

匿名用户的默认路径是/var/ftp/pub,我们是可以修改默认路径的

mkdir -p /var/tang/laotang6            #创建匿名路径

vim /etc/vsftpd/vsftpd.conf       #打开主配置文件,添加如下命令

anon_root=/var/tang         #指明匿名用户的路径为/var/tang

记得修改属主,才有权限写入哦!!

chown ftp /var/tang/laotang6                #修改属主为ftp

chmod o+w /var/tang                         #给予目录读写权限

客户端测试: OK(有读取权限)

本地用户:

本地用户配置还是比较简单,只要系统存在用户就可以登录,默认本地用户也是开启的。

useradd tang            #创建帐号tang

password tang           #修改用户tang的密码

vim /etc/vsftpd/vsftpd.conf       #打开主配置文件,关闭匿名用户

注意,这里只要把匿名用户no掉就行了,不用一条条注释它们。

systemctl restart vsftpd        #重启

客户端测试:OK (有读取权限)

登录成功(路径是用户的家目录例如我的路径是:/home/tang)

本地用户的默认路径是/home/用户名,我们是可以修改默认路径的

mkdir -p /var/laotang/tang            #创建本地路径

vim /etc/vsftpd/vsftpd.conf       #打开主配置文件,添加如下命令

local_root=/var/laotang6             #指明本地用户的路径为/var/laotang6

chmod o+w /var/laotang6            #给予目录读写权限

客户端测试: OK(有权限写入)

虚拟用户:

虚拟用户相对来说是比较安全的,因为帐号,是虚拟出来的,不存在于本地,

虚拟用户我们来做个实验,让张三(有读写权限),李四(只有读取权限),

分别指向不同的文件目录。

mkdir /etc/ftp              #创建目录

cd /etc/ftp

vim/etc/ftp/user.txt        #添加如下内容,单行为帐号,双行为密码

将上面创建的帐号密码转化为数据库文件

db_load -T -t hash -f user.txt user.db

vim /etc/pam.d/laotang6        #建立pam配置文件,文件名自定义。进行以下配置

创建本地用户,给虚拟用户映射。

useradd laotang6            #创建帐号laotang6

password laotang6           #修改用户laotang6的密码

vim /etc/vsftpd/vsftpd.conf

注意:修改主配置文件中最下面的pam_service_name=vsftpd 为我们创建的laotang6

解释:

guest_enable=yes                 #开启虚拟用户模式

guest_username=laotang6  #隐射本地用户账号

user_config_dir=/etc/ftp         #创建用户独立的权限配置文件存放目录

chroot_local_user=yes            #将用户限制在主目录

pam_service_name=laotang6        #指定我们前面创建的pam文件

mkdir -p /home/laotang6/zhangsan/zs           #创建张三的共享目录

mkdir -p /home/laotang6/lisi/ls               #创建李四的共享目录

在指定的目录下cd /etc/ftp,以虚拟用户名创建的文件权限配置文件

cd /etc/ftp

vim zhangsan          #创建张三的权限配置文件(要以虚拟用户名做文件名)

chmod o+w /home/laotang6/zhangsan/zs          #给予目录读写权限

vim lisi

systemctl restart vsftpd        #重启

客户端测试: OK

 

张三(有读写权限)

李四(只有读取权限)

systemctl restart firewalld        #开启防火墙

允许防火墙

firewall-cmd --permanent --add-service=ftp

firewall-cmd --reload

以上实验配置完毕。