ftp是一种文件传输协议,我们以redhat6.9为服务器系统,来介绍一下ftp服务器,这里我们先介绍一下ftp协议工作的原理

ftp协议可以在不同类型的计算机之间传输文件,工作流程大致为

1:客户机向服务器发出请求,同时客户机随机的打开一个大于1024的端口等待与服务器建立连接

2:ftp服务器在端口21侦听到客户机的请求后,在服务器的21端口和客户机的端口建立一个ftp连接会话

3:当出现数据请求时,客户机再次随机打开一个大于1024的端口与服务器的20端口开始开始传输数据,传输完毕后,随机端口与20端口均自动关闭

4:客户机与服务器断开连接,客户机释放第一个建立连接的随机端口

介绍完工作原理,再来介绍一下工作模式

ftp有两种模式

主动模式/被动模式

主动模式的工作方式

1:客户机随机打开一个大于1024的端口n,与服务器的21端口进行连接

2:客户机使用n+1端口对连接进行监视

3:客户机向服务器发起数据传输,并再次随机打开一个大于1024的端口x

4:服务器收到数据连接请求后,用20端口与x建立数据连接

5:传输完毕后断开连接,释放端口x,端口m与服务器的21端口断开连接,释放m

被动模式的工作方式

1:客户机随机打开一个大于1024的端口n,与服务器的21端口进行连接

2:客户机使用n+1端口对连接进行监视

3:客户机向服务器表明自己处在被动模式

4:服务器向客户机发送请求,并随机打开一个大于1024的端口x

5:客户机收到请求后在自己的随机大于1024的端口上与服务器的随机端口x进行数据的传输

6:传输完毕后断开连接,释放随机端口,客户机端口n与服务器的21端口断开连接,释放服务器的随机端口x

总结,以上两种工作模式可以看出,区别在于有谁发出请求,如果是客户机主动发起请求,并等待服务器主动通过该请求建立数据连接,则被称为主动模式

反之,如果是服务器发起请求,并被动的等待客户机来建立数据连接,则为被动模式。
最明显的一点,服务器下的主动模式与被动模式连接皆为21端口,但数据传输,主动模式下为21端口,而被动模式下为一个随机大于1024的端口

ftp的用户类型

1:匿名用户  顾名思义,可以在没有用户名和密码的情况下访问ftp服务器的共享资源

2:本地用户  这是ftp服务器的本地用户,不仅可以访问ftp服务器的共享资源还可以访问自己的家目录

3:虚拟用户  非本地用户的ftp用户,相比本地用户,更加安全,虚拟用户只能访问ftp服务器的共享资源,没有操作其他资源的权限

我们主要以redhat6.9为例,ftp服务器的软件,但我们因此我i们在这里主要说的是vsftp

ftp服务的配置也非常的简单,ftp服务是一个直接开启就能使用的服务,我们主要介绍匿名用户和本地用户的配置方式

我们首先可以用

yum install vsftpd  来下载ftp服务

chkconfig vsftpd off  设置开机自启

service vsftpd status  查看ftp服务器当前的状态

service vsftpd start  开启ftp服务器 (前面说过,ftp服务器不需要任何配置可以直接开启使用)

下载完毕后可以使用rpm -ql vsftpd  来查看ftp服务的具体文件路径

这里需要注意的几个文件

/etc/vsftpd/vsftpd.conf  ftp服务的主配置文件

/etc/pam.d/vsftpd  ftp的pam认证文件

/var/ftp  匿名用户的主目录

/var/ftp/pub  匿名用户的下载目录

/etc/vsftpd/ftpusers  禁止使用vsftp的用户列表

/etc/vsftpd/user_list  禁止或允许使用vsftp的用户列表

主要就是这些文件的信息

配置一台匿名ftp服务器

需要对主配置文件的参数进行修改

anonymous_enable=yes  允许用户匿名访问ftp服务器

anon_upload_enable=yes  匿名用户可以上传文件

anon_mkdir_write_enable=yes  允许匿名用户具有新建文件夹的权限

配置到此就完成了

配置一台仅本地用户访问的ftp服务器

anonymous_enable=no  禁止匿名用户访问

local_enable=yes  允许本地用户访问

配置完成

linux服务基础之ftp服务的更多相关文章

  1. 关于linux服务器上搭建ftp服务的流程

    小龙最近折腾了一个阿里云的服务器,买完了就要开始做那么多那么多的功课,小龙对ssh也是一知半解的状态,做个小笔记,发布下整个ftp服务的搭建过程,大神勿喷:) 一.aliyun Linux(Redha ...

  2. linux Centos 6.5 FTP服务原理及vsfptd的安装、配置(转)

    本篇随笔将讲解FTP服务的原理以及vsfptd这个最常用的FTP服务程序的安装与配置... 一.FTP服务原理 FTP(File Transfer Protocol)是一个非常古老并且应用十分广泛的文 ...

  3. linux环境中安装ftp服务

    需求说明: 今天项目中有一个新的需求,需要在linux环境中搭建一个ftp服务,在此记录下. 操作过程: 1.通过yum的方式安装ftp服务对应的软件包 [root@testvm01 ~]# yum ...

  4. 利用vsftpd在Linux构建安全的FTP服务

    最近在机房搭建Linux环境,需要用到了FTP服务,查看了许多的资料,在这里做一下笔记 一.安装 方法一,使用yum命令安装,需要能够连接外网 # yum install vsftpd 方法二,使用安 ...

  5. Linux系统安装及配置ftp服务

    1. 先用rpm -qa| grep vsftpd命令检查是否已经安装,如果ftp没有安装,使用yum  -y  install vsftpd 安装,(ubuntu 下使用apt-get instal ...

  6. Linux安装与使用FTP服务-vsftpd

    简介 vsftpd 是"very secure FTP daemon"的缩写,安全性是它的一个最大的特点.vsftpd 是一个 UNIX 类操作系统上运行的服务器的名字,它可以运行 ...

  7. windows和linux传输小技巧——FTP服务

    目录 一.FTP简介 二.匿名用户访问设置 三.设置本地用户验证访问ftp 3.1.修改匿名用户.本地用户登录的默认根目录 四.使用user_list列表 一.FTP简介 FTP服务--用来传输文件的 ...

  8. Linux(Centos7) 实例搭建 FTP 服务

    本文以 CentOS 7.2 64位系统为例,使用 vsftpd 作为 FTP 服务端,FileZilla 作为客户端.指导您如何在 Linux 云服务器上搭建 FTP 服务. 操作步骤 安装 vsf ...

  9. 在linux中下载安装FTP服务

    一.环境及需求 阿里云服务器的Centos6.9版本,当时需要用到上传服务,所以我想着先搭建一个ftp,比较方便快捷,但是我参考了网上好多的博客,简单安装是没问题,但是时不时还会遇到好多坑,与其说是博 ...

随机推荐

  1. ref 和 out 的区别

    ref和out都是C#中的关键字,所实现的功能也差不多,都是指定一个参数按照引用传递. 对于编译后的程序而言,它们之间没有任何区别,也就是说它们只有语法区别. 总结起来,他们有如下语法区别: 1.re ...

  2. 转:ITopologicalOperator Buffer调用异常的解决方法(来源网络)

      /// <summary>   /// 用拓扑分析求出缓冲区范围.   /// 由于ArcGIS的问题,有时调用会出异常,因此需要循环调用   /// </summary> ...

  3. ImageLoader简单使用

    效果图就是一个从网络加载的图片:在加载的时候图片的中间显示一个进度条 数据是随便找的一个网络图片的地址 导入jar包universal-image-loader-1.9.5 用来展示商品使用    在 ...

  4. javascript面向对象的写法01

    类和对象 其他面向对象的语言类的语法是内置的,自然而然的事.javascript中有对象,但没有类的语法,类的实现需要模拟出来. 只需要把对象想成一个容器,里面存放一些属性或方法,把类想象成一个对象的 ...

  5. 推荐一个很好用的脚本session snapper

    源网址http://tech.e2sn.com/oracle-scripts-and-tools/session-snapper 内容: If you want to just download Sn ...

  6. 一、Python安装下载

    下载地址:https://www.python.org/downloads/ 因为Python3.X和2.X有部分不兼容,有些不向下兼容,现在3.5的资料和插件少,故我就学习的2.7.11了; 下载后 ...

  7. 如何为属性是disabled的表单绑定js事件

    $(document).click(function(e){ var el = e.target; if (el.tagName == 'INPUT') { $(el).removeAttr('dis ...

  8. Scrum第一次冲刺

    1.项目描述 为了长大学子的便捷,避免遭遇官网爆炸而无法查询成绩,课表等相关个人信息.我们决定开发长大Tips(分担官网的压力). 2.基本业务 用户可以通过学号加密码登入长大Tips 用户可以在在用 ...

  9. Git 还没push 前可以做的事(转)

    Git 版本控制系統(3) 還沒 push 前可以做的事 转载:http://ihower.tw/blog/archives/2622   這一集要講的是:還沒 push 前可以做的壞事,也就是 re ...

  10. POJ 3321 Apple Tree 【树状数组+建树】

    题目链接:http://poj.org/problem?id=3321 Apple Tree Time Limit: 2000MS Memory Limit: 65536K Total Submiss ...