1.ftp与sftp

大致了解下:

ftp是一个文件传输协议,linux环境需要它才能支持文件的传输与查看,它的默认端口是21。

sftp是加密/解密的文件传输协议,因为它每次传输都有加密解密的步骤,所以效率比ftp低的多但是安全。

2.ftp服务的安装

使用命令行从软件库下载安装:apt-get install vsftp ftp

3.ftp服务的匿名访问测试

安装完成后我们可以进行测试,首先测试一下匿名登录

修改vsftpd的配置文件:vim /etc/vsftpd.conf(配置文件的位置可能不同)

将anonymous_enable设置为YES,意思是允许匿名登录;

再添加一行匿名登录的默认目录:anon_root=/home/annoDir;

最后启动vsftpd服务:/etc/init.d/vsftpd start

用浏览器匿名访问目录:

可以看到,无需输入账号密码就可以访问annoDir这个目录:

4.ftp服务的配置详解

参考(https://www.linuxidc.com/Linux/2017-04/142493.htm

anonymous_enable=NO             # 关闭匿名登录 默认为NO
local_enable=YES            # 允许本地用户登录
write_enable=YES            # 启用可以修改文件的 FTP 命令
local_umask=022               #设置本地用户新增文档的umask,默认为022,
这里的022ftp服务会把它解析成2进制的000 010 010 再取反,即755,代表了文件的权限,即 对新增的目录有读写执行权
dirmessage_enable=YES           # 当用户第一次进入新目录时显示提示消息(按照默认就好)
xferlog_enable=YES          # 一个存有详细的上传和下载信息的日志文件(启用日志文件)
connect_from_port_20=YES        # 在服务器上针对 PORT 类型的连接使用端口 20(FTP 数据)
xferlog_std_format=YES          # 保持标准日志文件格式(默认不动)
listen=NO                 # 阻止 vsftpd 在独立模式下运行,默认为NO,但是据说设置为NO的话,有些配置功能会被限制(找不到相关资料)
listen_ipv6=YES             # vsftpd 将监听 ipv6 而不是 IPv4,你可以根据你的网络情况设置,如果需要同时支持ipv4和ipv6的话,需要配置2套
pam_service_name=vsftpd         # vsftpd 将使用的 PAM 验证设备的名字(默认就好)
userlist_enable=YES             # 允许 vsftpd 加载用户名字列表,
注意,默认vsftp是基于/etc/vsftpd.userlist来作为禁止访问ftp的名单的,比如其中就包含root用户
我们也可以通过配置 userlist_deny=NO 这个选项来反转配置,即只有该名单内的用户可以访问该目录。
chroot_local_user=YES
allow_writeable_chroot=YES

 #选项chroot_local_user=YES 表示本地用户将进入 chroot 环境,当登录以后默认情况下是其 home 目录

 并且我们要知道,默认情况下,出于安全原因,VSFTPD 不允许 chroot 目录具有可写权限。然而,我们可以通过选项 allow_writeable_chroot=YES 来允许。

chroot_list_enable=YES #限制只访问自身目录

chroot_list_file=/etc/vsftpd/vsftpd.chroot_list  #限制访问自身目录的用户列表

5.新增ftp用户

正常使用ftp服务,很少会用匿名登录,我们需要一个专门的用户去做ftp操作。

1.新建用户(xjxftp)并设置主目录和密码:

2.在ftp的配置文件中限制用户的访问路径:

编辑vsftpd.conf文件,设置chroot_local_user=YES

同时,新建一个chroot_list文件,将受限制的用户加入:一个用户名占一行,直接加入就好。

重启服务:root@instance-7k2jqcks:/etc# ./init.d/vsftpd restart

注:如果我们设置了chroot_local_user=YES,又设置了chroot_list_enable=YES限制访问自身目录,则拥有写权限的用户将无法登录:

这是由于ftp新版本的安全机制导致的(https://www.cnblogs.com/zhjh256/p/9155281.html

我们当然不能没有写的权限,这里我们可以设置 allow_writeable_chroot=YES 来允许(如果white_enable=YES这行被注释掉的话也把它放开)

这样,我们使用xftp就可以新建文件,并且所有的操作也被限制在该用户主目录下:

6.ftp用户无法新建文件夹和403

这里稍微说一点点遇到的小问题,一个是提到的限制用户访问主目录后的无法写的问题,上面的已经有方案了。

403的问题:

1.如果我们使用阿里云服务器,它进入的协议和端口默认是有限制的,我们需要自己做安全组配置打开20和21端口,如果服务器自带防火墙也一样。

2.还有就是你ftp登录的用户有没有对主目录应有的访问读写权限。

3.默认ftp是对ftpusers这个文件里的用户禁止访问的。它里面就包含root,如果我们的用户在/etc/ftpusers这个文件夹里,登录验证也将失败。

无法新建文件夹的问题:注意有的版本配置文件中write_enable=YES 这个是被注释掉的,这样我们无法写,需要把它打开。

7.vsftpd配置必须需要账号密码访问

把user_list文件作为允许访问的用户列表

配置文件中 配置 userlist_enable=YES和 userlist_deny=NO

Ubuntu16 FTP的安装,基本配置与权限控制的更多相关文章

  1. Linux FTP的安装与配置

    Linux FTP的安装与配置   ftp安装部分,操作步骤如下: 可以使用yum命令直接安装ftp # yum install vsftpd ftp服务的开启与关闭命令: 开启:# service  ...

  2. Linux FTP的安装与配置(转)

    Linux FTP的安装与配置   ftp安装部分,操作步骤如下: 可以使用yum命令直接安装ftp # yum install vsftpd ftp服务的开启与关闭命令: 开启:# service  ...

  3. Linux ftp软件安装、配置和启动

    ftp软件安装.配置和启动及相关问题的解决在测试环境使用过程中经常使用.本文以SuSE11sp1上vsftpd的安装过程进行介绍. 测试环境 SuSE11sp1 vsftp软件安装检查 1.rpm - ...

  4. CentOS 7 FTP的安装与配置

    CentOS7 FTP安装与配置 1.FTP的安装 #安装yum install -y vsftpd #设置开机启动systemctl enable vsftpd.service #启动systemc ...

  5. Ubuntu16.04 oh_my_zsh 安装与配置

    参考文章 Ubuntu上使终端显示Git分支(oh-my-zsh) oh-my-zsh的安装与基本配置 Ubuntu 下安装oh-my-zsh 前言 之前学习Laravel的时候,经常要切换git分支 ...

  6. Ubuntu16.04下安装和配置Redis

    一.前提条件 需要连接互联网,然后执行sudo apt-get update更新软件包 二.执行安装命令 sudo  apt-get install redis-server 执行后如下图所示,我们输 ...

  7. CentOS7下FTP的安装与配置

    1.安装vsftpd 1 [root@localhost modules]# yum install -y vsftpd 2.编辑ftp配置文件 1 [root@localhost modules]# ...

  8. Ubuntu16.04.3安装并配置samba方法

    目的:单个Linux用户可以在windows电脑上通过映射网络驱动器的方式来访问自己的工作目录. 方法如下: 1.安装smb服务器:apt-get install samba2.安装smb支持的文件系 ...

  9. ftp server安装与配置

    http://note.youdao.com/noteshare?id=905513cfcdba7d6a8d2fbdd0874a6259

随机推荐

  1. VMware 非简易安装centos6(静态ip配置)

    1.选择新建虚拟机 在弹出框中我选择推荐安装 然后点击下一步 2.选择稍后安装操作系统(不然会默认简易安装) 接着一直下一步就可以了,最后到这个页面 4.如下图选择事先下载好的安装文件 5.配置桥接模 ...

  2. [ Java面试题 ]算法篇

    1.堆和栈在内存中的区别是什么? 概念: 栈(stack)是为执行线程留出的内存空间.当函数被调用的时候,栈顶为局部变量和一些 bookkeeping 数据预留块.当函数执行完毕,块就没有用了,可能在 ...

  3. yii2.0 app上集成支付宝支付

    1.首先从支付宝官网下载支付宝app支付sdk 地址 : https://doc.open.alipay.com/docs/doc.htm?spm=a219a.7629140.0.0.hLEa5O&a ...

  4. transform-origin

    transform-origin:改变原点中心位置 transform-origin是变形原点,也就是该元素围绕着那个点变形或旋转,transform-origin并不是transform中的属性值, ...

  5. RabbitMQ分布式集群架构和高可用性(HA)

    (一) 功能和原理 设计集群的目的 允许消费者和生产者在RabbitMQ节点崩溃的情况下继续运行 通过增加更多的节点来扩展消息通信的吞吐量 1 集群配置方式 RabbitMQ可以通过三种方法来部署分布 ...

  6. 搭建 vue2 单元测试环境(karma+mocha+webpack3)

    从网上找了很多例子关于单元测试,都是如何新建项目的时候的添加单元测试,用vue-cli中怎么添加,但是我的项目已经生成了,不能再一次重新初始化,这时如何添加单元测试,这里面遇到了好多坑,写在这里记录一 ...

  7. 【树状数组】Bzoj1878[SDOI2009] HH的项链

    Description HH有一串由各种漂亮的贝壳组成的项链.HH相信不同的贝壳会带来好运,所以每次散步 完后,他都会随意取出一段贝壳,思考它们所表达的含义.HH不断地收集新的贝壳,因此, 他的项链变 ...

  8. BZOJ_3038_上帝造题的七分钟2_线段树

    BZOJ_3038_上帝造题的七分钟2_线段树 题意: XLk觉得<上帝造题的七分钟>不太过瘾,于是有了第二部. "第一分钟,X说,要有数列,于是便给定了一个正整数数列. 第二分 ...

  9. 哎呀,我老大写Bug啦——记一次MessageQueue的优化

    MessageQueue,顾名思义消息队列,在系统开发中也是用的比较多的一个中间件吧.我们这里主要用它来做日志管理和订单管理的,记得老老大(恩,是的,就是老老大,因为他已经跳槽了)还在的时候,当时也是 ...

  10. 分布式系统关注点(17)——先写DB还是「缓存」?

    如果第二次看到我的文章,欢迎右侧扫码订阅我哟~