在centos7安装ftp服务

 yum install -y vsftpd

启动服务

systemctl start vsftpd

自启动

systemctl enable vsftpd

查看端口

注意关闭SELinux和本地防火墙,否则不能正常操作

重要文件

/var/ftp/pub/  默认共享目录

/etc/vsftpd/vsftpd.conf  主配置文件

/etc/vsftpd/user_list  黑名单,可修改成白名单

/etc/vsftpd/ftpusers  黑名单

FTP相关用户

匿名用户

anonymous或ftp

本地用户

Linux系统用户 

虚拟用户

管理员自定义用户

配置文件/etc/vsftpd/vsftpd.conf

anonymous_enable=YES             ### 允许匿名登录,建议关闭
local_enable=YES ### 允许本地用户登录
write_enable=YES ### 允许对文件系统做改动的 FTP 命令
local_umask= ### 本地用户创建文件所用的 umask 值
dirmessage_enable=YES ### 当用户首次进入一个新目录时显示一个消息
xferlog_enable=YES ### 用于记录上传、下载细节的日志文件
connect_from_port_20=YES ### 主动模式数据传输接口
xferlog_std_format=YES ### 使用标准的ftp日志格式
listen=NO ### 不要让 vsftpd 运行在独立模式
listen_ipv6=YES ### vsftpd 将监听 IPv6 而不是 IPv4
pam_service_name=vsftpd ### vsftpd 使用的 PAM 服务名
userlist_enable=YES ### 用户登入限制
tcp_wrappers=YES ### 使用 tcp wrappers

匿名用户登入

在默认情况下,ftp可以用匿名用户登入,登入的目录为/var/ftp/

用户名为anonymous或ftp,密码为空,建议关闭

默认情况下,只能在对应的目录下进行下载文件,不能上传文件

可以修改对应的配置文件,允许匿名用户进行文件上传和建立目录的权限

配置文件/etc/vsftpd/vsftpd.conf中将以下两行注释去掉即可

anon_upload_enable=YES        #允许上传文件
anon_mkdir_write_enable=YES #允许建立目录

重启服务,同时还需要让ftp作为/var/ftp/pub的所有者

chown ftp pub/

重新用匿名用户登入ftp就可以在pub/上传文件和建立目录

系统用户登入

采用Linux的系统用户作为ftp服务的用户进行登入,但是因为ftp是明文传递,如果被人截获数据包,就相当于获得Linux的用户和密码,因此建议关闭

默认情况下,采用系统用户登入,可以进行上传下载,目录为用户的家目录

可以修改配置文件更换系统用户的登入位置,在/etc/vsftpd/vsftpd.conf添加

local_root=/tmp/test_home/

然后建立对应的目录 mkdir /tmp/test_home,重启服务

再次登入ftp,目录为/tmp/test_home,其他Linux用户登入ftp服务也是在这个目录(注意系统的目录权限)

但是用系统用户登入ftp存在一个缺陷,即可以切换到根目录,可以窃取其他目录的信息,所以我们需要把系统用户禁锢在家目录下

进入配置文件,把这句话前面的注释去掉,然后重启服务,即把所有的系统用户限制在家目录下

chroot_local_user=YES

注意一个特别配置,如果把这三句都去掉注释,同时在/etc/vsftpd/建立一个chroot_list,里面的内容为系统用户,那么写在这里的系统用户则可以访问任何目录

chroot_local_user=YES
chroot_list_enable=YES
chroot_list_file=/etc/vsftpd/chroot_list

假如我们在/etc/vsftpd/chroot_list添加一个系统用户test2,那么这个系统用户登入ftp服务器,则可以访问根目录,也可以访问其他目录

黑名单与白名单

/etc/vsftpd/ftpusers和 /etc/vsftpd/user_list默认情况下都是黑名单,但是/etc/vsftpd/user_list可以通过配置文件修改成白名单

在/etc/vsftpd/vsftpd.conf配置文件中

userlist_enable=YES  #在这句下面添加以下两句,将user_list反转成白名单
userlist_deny=NO
userlist_file=/etc/vsftpd/user_list

注意黑名单的权限比白名单大,即同时存在与黑名单和白名单,依旧被禁用

虚拟用户登入

比较安全和常见的登入方式为虚拟用户登入,即只能登入ftp服务器

1、添加一个虚拟用户口令文件

vim /etc/vsftpd/vuser.txt

在里面输入虚拟用户和密码

vtest  #账户
test #密码
vtest2 #账户
test2 #密码

2、生成认证文件

db_load -T -t hash -f /etc/vsftpd/vuser.txt  /etc/vsftpd/vuser.db

如果没有安装口令认证文件先安装

 yum -y install db4-utils

3、编辑pam认证文件

进入 /etc/pam.d/vsftpd,注释掉原来的内容,因为系统登入依赖这个文件
 在后面添加两行

auth required  /lib64/security/pam_userdb.so db=/etc/vsftpd/vuser
account required /lib64/security/pam_userdb.so db=/etc/vsftpd/vuser

4、建立本地映射用户

useradd -d /home/vftproot -s /sbin/nologin vuser
chmod /home/vftproot

5、修改配置文件

在/etc/vsftpd/vsftpd.conf下面添加

guest_enable=YES
guest_username=vuser
user_config_dir=/etc/vsftpd/vuser_conf

然后重启服务,就可以进行虚拟用户登入,记得删除原来的vuser.txt文件

虚拟用户进行目录分配

mkdir /etc/vsftpd/vuser_conf

在这个目录下创建文件,文件名为虚拟用户名,在里面指定权限和目录,没有设置的虚拟用户则根据主配置文件

 vim /etc/vsftpd/vuser_conf/vtest2 
anon_upload_enable=YES
anon_mkdir_write_enable=YES
local_root=/tmp/vtest2
mkdir /tmp/vtest2
chown vuser vtest2/

并在配置文件中添加

allow_writeable_chroot=YES

重启服务,再次登入,可以正常使用

FTP安装及配置的更多相关文章

  1. [Windows Server 2003] IIS自带FTP安装及配置方法

    ★ 欢迎来到[护卫神·V课堂],网站地址:http://v.huweishen.com★ 护卫神·V课堂 是护卫神旗下专业提供服务器教学视频的网站,每周更新视频.★ 本节我们将带领大家:IIS6.0自 ...

  2. Linux下FTP安装与配置

    第一部分 .note-content {font-family: 'Helvetica Neue', Arial, 'Hiragino Sans GB', STHeiti, 'Microsoft Ya ...

  3. [转]CentOS 5.5下FTP安装及配置

    一.FTP的安装 1.检测是否安装了FTP : [root@localhost ~]# rpm -q vsftpd vsftpd-2.0.5-16.el5_5.1 否则显示:[root@localho ...

  4. CentOS7 FTP安装与配置

    1.FTP的安装 #安装yum install -y vsftpd #设置开机启动systemctl enable vsftpd.service #启动systemctl start vsftpd.s ...

  5. IIS6自带FTP安装及配置方法

    参考:http://v.huweishen.com/video/9.html ·IIS自带的FTP服务是最安全的,不会像Serv-U那样存在各种漏洞:但其配置过程也比较复杂. ·本节将以虚拟目录方式, ...

  6. 从零开始搭建系统1.7——FTP安装及配置

    1.安装vsftp软件包 [root@localhost usr]# yum install -y vsftpd 2.先备份vsftpd的默认配置文件 [root@localhost usr]# cd ...

  7. centos 6.4 FTP安装和配置

    链接地址:http://blog.csdn.net/wind520/article/details/38019647 1: 安装 检查是否安装 [root@localhost ~]# rpm -qa ...

  8. linux ftp安装和配置

    1. 启动VSFTP服务器 A:cenos下运行:yum  install  vsftpd B. 登录Linux主机后,运行命令:"service vsftpd start"C. ...

  9. Linux 安装及配置 Nginx + ftp 服务器

    Nginx 安装及配置 一.Nginx 简介: Nginx("engine x") 是一款是由俄罗斯的程序设计师 Igor Sysoev 所开发高性能的 Web和 反向代理服务器, ...

随机推荐

  1. 最全的三剑客和linux正则符号讲解

    第2章 linux符号系列与三剑客    194 2.1 特殊符号系列    194 2.1.1 普通符号系列    194 2.1.2 引号符号系列    196 2.1.3 定向符号    197 ...

  2. SpringBoot系列之Spring Data Jpa集成教程

    SpringBoot系列之Spring Data Jpa集成教程 Spring Data Jpa是属于Spring Data的一个子项目,Spring data项目是一款集成了很多数据操作的项目,其下 ...

  3. Kinect-v2 Examples with MS-SDK(译文二)

    K2-asset提供的脚本组件 K2-asset在KinectScripts文件夹中提供通用脚本组件,并在KinectDemos / 文件夹的相应脚本子文件夹中提供特定于演示的组件.可以在自己的Uni ...

  4. 记录XunSearch(讯搜)的使用教程步骤(CentOS7下)

    一.安装编译工具 yum install make gcc g++ gcc-c++ libtool autoconf automake imake mysql-devel libxml2-devel ...

  5. centos7—计划任务(at、cron)

    centos7—计划任务(at.cron) 2018-08-08 14:33:17 coisini_覔 阅读数 3751更多 分类专栏: Linux基础 crond/at   版权声明:本文为博主原创 ...

  6. JavaScript构造函数学习笔记分享

    构造函数就是一个普通的函数,创建方式和普通函数没有区别 不同的是构造函数名习惯上首字母大写 普通函数是直接调用,而构造函数需要使用new关键字来调用 构造函数的执行流程: 立刻创建一个新的对象 将新建 ...

  7. 【Git】学习开始

    [Git]学习开始 转载:https://www.cnblogs.com/yangchongxing/p/10172683.html 在线电子书籍:https://git-scm.com/book/z ...

  8. c++ const问题小记

    int* a = new int; const int* b = a; const int* a = new int; int* b = (int*)a; const int m = 10; int ...

  9. 使用t-SNE做降维可视化

    最近在做一个深度学习分类项目,想看看训练集数据的分布情况,但由于数据本身维度接近100,不能直观的可视化展示,所以就对降维可视化做了一些粗略的了解以便能在低维空间中近似展示高维数据的分布情况,以下内容 ...

  10. 基于Tomcat部署的Geoserver配置Geowebcache,并转发ArcGIS切片

    1.将GeowebCache的war包解压到tomcat的webapp下,打开war包中的WEB-INF中的web.xml文件,同时创建一个你想保存geowencache的切片的空文件夹,例如我命名叫 ...