vsftpd端口的作用:
控制连接:tcp21端口用于发送FTP命令
数据连接:tcp20端口用于上传下载数据

传输模式:分为主动模式和被动模式
主动模式是当需要传输数据时,客户端以PORT命令告知服务器,我打开了某个端口,你过来连我呀!服务器会从20端口向客户端的该端口发送请求并建立数据连接,
被动模式是当需要传输数据时,服务端以PASV命令告知客户端,我打开了某个端口(非20端口),你过来连我呀!于是客户端向服务器的该端口发送请求并建立数据连接,

用户类型:匿名用户,虚拟用户,本地用户,

vsftpd默认有两个用户黑名单:在安装目录,分别为:ftpusers user_list,ftpusers用户黑名单优先级大于user_list,可将将user_list黑名单改为白名单,修改配置文件:
userlist_enable=YES
userlist_deny=NO #手动添加
从新加载服务器就可以了,

匿名用户搭建:
服务端
准备匿名用户访问FTP的目录:
默认是在/var/ftp/pub
修改pub目录权限,将属主改为ftp
chown -R ftp pub
安装vsftp:
yum -y install vsftpd
vim /etc/vsftpd/vsftpd.conf
anonymous_enable=YES
local_enable=YES
write_enable=YES
local_umask=022
anon_upload_enable=YES #开起匿名用户上传权限
anon_umask=022 #手动添加匿名用户权限掩码
anon_mkdir_write_enable=YES #开起匿名用户创建目录的权限
anon_other_write_enable=YES #手动添加其他用户创建目录的权限
xferlog_enable=YES
xferlog_std_format=YES
xferlog_file=/var/log/xferlog #手动添加日志的输出路径
启动vsftp
/etc/init.d/vsftpd start

客户端:安装一个ftp命令
yum -y install ftp
ftp 192.168.1.1 #这就可以测试了,登录的时候用ftp登录,密码随便
以上匿名用户搭建全部结束

本地用户搭建
先在本地创建两个用户用于测试用
修改默认的配置文件,修改两个地方即可;
vim /etc/vsftpd/vsftpd.conf
local_umask=077 #将本地用户的目录权限掩码改为077
chroot_local_user=YES #开起本地用户的目录权限
从新加载服务器就可以了
/etc/init.d/vsftpd reload

客户端测试登录时输入用户名密码即可

搭建虚拟用户验证FTP服务
1、先创建一个虚拟用户账号密码的列表文件
[root@centos101 vsftpd]# cat vusers.list
zhangsan
123
list
123
wangwu
123
使用db_load工具生成数据库文件
[root@centos101 vsftpd]# db_load -T -t hash -f vusers.list vusers.db
[root@centos101 vsftpd]# ls
ftpusers user_list vsftpd.conf vsftpd.conf.bak vsftpd_conf_migrate.sh vusers.db vusers.list
db_load命令注释:-T 允许非Berkeley的程序使用数据库, -t 指定算法, -f 指定源文件, 注意:生成的数据库文件必须以db结尾。
[root@centos101 vsftpd]# chmod 600 vusers*
-rw------- 1 root root 12288 5月 11 11:48 vusers.db
-rw------- 1 root root 33 5月 11 11:46 vusers.list #为了安全,修改有关用户文件的权限

2、添加虚拟映射账户,并修改其权限
[root@centos101 vsftpd]# useradd -d /var/ftproot/ -s /sbin/nologin virtual
[root@centos101 var]# chmod 755 ftproot/
drwxr-xr-x 4 virtual virtual 4096 5月 11 11:53 ftproot/

3、增加pam认证
[root@centos101 vsftpd]# cat /etc/pam.d/vsftpd.new #这个文件手动创建
auth required pam_userdb.so db=/etc/vsftpd/vusers
account required pam_userdb.so db=/etc/vsftpd/vusers #这里可以不写文件名后缀

4、修改配置文件
[root@centos101 vsftpd]# vim vsftpd.conf
anon_umask=022 #手动添加
pam_service_name=vsftpd.new #这里改为pam认证自己创建的那个文件名
guest_enable=YES #手动添加
guest_username=virtual #手动添加,这个是创建的账户

客户端测试就可以了

为每个用户创建不同的根目录,不同权限管理
先创建一个统一管理用户权限文件的目录
[root@centos101 vsftpd]# mkdir vusers.dir
[root@centos101 vusers.dir]# touch zhangsan lisi wangwu
lisi wangwu zhangsan
[root@centos101 vusers.dir]# cat zhangsan #内容全部手写
anon_upload_enable=YES #开起匿名用户上传权限
anon_mkdir_write_enable=YES #开起匿名用户创建目录的权限
anon_other_write_enable=YES #开起其他用户创建目录的权限
anon_max_rate=5 #传输速率为每秒5字节,0为不限制传输速率
local_root=/var/zhangsan #根 目录
[root@centos101 vusers.dir]# cat lisi
anon_upload_enable=YES
anon_max_rate=0
local_root=/var/lisi
wangwu的权限不做设置,为默认权限,仅可以下载,不可以上传
然后修改配置文件,在最后加入一行;
[root@centos101 vsftpd]# vim vsftpd.conf
[root@centos101 vsftpd]# tail -1 vsftpd.conf
user_config_dir=/etc/vsftpd/vusers.dir/
重新加载服务

vsftp搭建文档的更多相关文章

  1. 环境搭建文档——Windows下的Python3环境搭建

    前言 背景介绍: 自己用Python开发了一些安卓性能自动化测试的脚本, 但是想要运行这些脚本的话, 本地需要Python的环境. 测试组的同事基本都没有安装Python环境, 于是乎, 我就想直接在 ...

  2. 生产环境轻量级dns服务器dnsmasq搭建文档

    dnsmasq搭建文档 一.生产环境域名解析问题 之前生产环境设备较少,是通过维护master(192.168.1.1)设备的hosts文件实现的.每次新增设备后,需要在master的hosts文件中 ...

  3. kafka集群搭建文档

    kafka集群搭建文档 一. 下载解压 从官网下载Kafka,下载地址http://kafka.apache.org/downloads.html 注意这里最好下载scala2.10版本的kafka, ...

  4. VUE CLI环境搭建文档

    VUE CLI环境搭建文档 1.安装Node.js 下载地址 https://nodejs.org/zh-cn/download/ 2.全局安装VUE CLI win+R键打开运行cmd窗口输入一下代 ...

  5. OpenStack Pike超详细搭建文档 LinuxBridge版

    前言 搭建前必须看我 本文档搭建的是分布式P版openstack(1 controller + N compute + 1 cinder)的文档. openstack版本为Pike. 搭建的时候,请严 ...

  6. OpenStack Ocata 超详细搭建文档

    前言 搭建前必须看我本文档搭建的是分布式O版openstack(controller+ N compute + 1 cinder)的文档.openstack版本为Ocata.搭建的时候,请严格按照文档 ...

  7. 使用ghpage(github服务)搭建文档网站几种方式

    可以通过github提供的ghpage服务来搭建网站,有以下三种方式来实现: 1.文档放在master分支,作为一个子目录. 仓库:https://github.com/Ourpalm/ILRunti ...

  8. Readthedocs+Github搭建文档

    一.文档撰写前提 环境部署: > git clone https://github.com/toooney/demo-readthedocs.git > pip install sphin ...

  9. 推荐一个vuepress模板,一键快速搭建文档站

    介绍 vuepress-template是一个简单的VuePress案例模板,目的是让用户可以直接clone这个仓库,作为初始化一个VuePress网站启动项目,然后在这个项目的基础上新增自定义配置和 ...

随机推荐

  1. 人脸识别1:n对比 (一)

    本项目采用了 Face++人脸识别 第三方接口,实现了自选本地手机相册图片上传人脸(faceSet中添加人脸) 和 自选本地手机相册图片寻找出集合中相似度最高的一个face,可返回比对相似度等信息. ...

  2. 探索未知种族之osg类生物---渲染遍历之裁剪二

    前言 上一节我们大致上过了一遍sceneView::cull()函数,通过研究,我们发现上图中的这一部分的代码才是整个cull过程的核心部分.所以今天我们来仔细的研究一下这一部分. sceneView ...

  3. Python之路(第三十六篇)并发编程:进程、同步异步、阻塞非阻塞

    一.理论基础 进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一.操作系统的其他所有内容都是围绕进程的概念展开的. 即使可以利用的cpu只有一个(早期的 ...

  4. vue项目部署到服务器

    1.配置config目录下index.js index: path.resolve(__dirname, '../dist/index.html'), assetsRoot: path.resolve ...

  5. javaMail的使用以及trying to connect to host "1xxx@163.com", port 25, isSSL false异常

    最近项目用到邮件系统,开始了解javaMail...话不多说先上代码: pom依赖: <!--    邮件  https://mvnrepository.com/artifact/javax.m ...

  6. Newtonsoft.Json 时间格式化

    时间序列化经常多个T:“2017-01-23T00:00:00” 解决方案: 日期格式化输出,指定IsoDateTimeConverter的DateTimeFormat即可 IsoDateTimeCo ...

  7. gulp打包工具

    首先安装全局gulp $ npm install --global gulp 下载成功后 新建一个项目或者一个文件夹(做测试) mkdir testgulp 在该文件或者项目下下载gulp工具 $ n ...

  8. Greenplum 日常维护手册 (汇总、点评、备查)

    1. 数据库启动:gpstart常用可参数: -a : 直接启动,不提示终端用户输入确认-m:只启动master 实例,主要在故障处理时使用2. 数据库停止:gpstop:常用可参数:-a:直接停止, ...

  9. abaqus邓肯张模型umat

    首先是始点刚度法: SUBROUTINE UMAT(STRESS,STATEV,DDSDDE,SSE,SPD,SCD, RPL,DDSDDT,DRPLDE,DRPLDT, STRAN,DSTRAN,T ...

  10. git使用之后悔药

    1.工作区的代码想撤销 背景:有时候编写了一大段代码之后,想要撤销更改(执行add操作之前), 命令:git checkout -- <file路径> 使用git checkout -- ...