Linux文件共享服务之Vsftp

Vsftp (Very Security ftp) :非常安全的FTP应用,基于FTP服务开发的应用
FTP的工作原理:
FTP会话时包含了两个通道,一个叫控制通道,一个叫数据通道。控制通道是和FTP服务器进行沟通的通道,连接FTP、发送FTP指定都是通过控制通道来完成的。数据通道是和FTP服务器进行文件传输或者列表的通道。FTP协议中,控制连接都是由客户端发起的,而数据连接有两种工作方式:PORT(主动)方式PASV(被动)方式 (主动和被动是对于客户端来说的)

  • 主动模式:服务器开放 20 21 号端口
  • 被动模式:服务器开放 21 号端口以及一个随机端口,其中21号端口固定用来做控制链接 

简单概述为:主动模式是传送数据时是 服务器 连接到客户端的端口;而被动模式则是客户端连接到服务器的端口。主动模式需要客户端必须开放端口给服务器,很多客户端都是在防火墙内部,开放端口给FTP服务器比较困难;而被动模式则只需要服务器开放端口给客户端就行了。一般被动模式是用的比较多

FTP用户类型:

  • 匿名用户:anonymous 或者 ftp
  • 本地用户:服务器本身的用户家目录为共享目录
  • 虚拟用户:使用独立账户密码数据文件的用户

常见的FTP服务程序:
Vsftpd、IIS 、Server-U、wu-ftp、proftp
主要配置文件:

  • /etc/vsftpd/vsftpd.conf :主配置文件
  • /etc/vsftpd/ftpusers :黑名单
  • /etc/vsftpd/user_list:黑白名单

Vsftp服务的搭建

服务器端 (Rhel7      ip: 192.168.10.17)
客户端    (Centos 6.5 ip: 192.168.110.24)

  1. 服务器端关闭Selinux :setenforce  0  ; 配置防火墙: firewall-cmd   --add-service=ftp
  2. 服务器端安装 vsftpd 程序:yum  -y  install  vsftpd
  3. 修改共享目录属主属组:  chown  ftp:ftp   /var/ftp/pub  -R
  4. 创建本地登录用户并且设置密码:useradd  -s  /sbin/nologin   test  ;  passswd    test
  5. 修改配置文件  /etc/vsftpd/vsftpd.conf ,启动 vsftp 服务 systemctl  start  vsftpd
  6. 客户端关闭Selinux和防火墙:setenforce  0  ; service  iptables  stop
  7. 客户端安装 lftp 或者 ftp: yum -y  install lftp  或  yum  -y  install  ftp
  8. 客户端使用 lftp 或 ftp 登录,共享的是 /var/ftp/pub ,客户端使用本地用户 test 登录,共享的是 test用户的家目录
  9. 无论是lftp还是ftp,上传都是 put 文件名  ,下载都是 get 文件名

注:使用lftp登录默认是匿名用户登录不用输密码。使用ftp登录的话,可以使用服务器的本地用户登录,也可以使用账户名为ftp的匿名用户登录

注:vsftpd安装好后,会自动创建文件夹  /var/ftp/pub ,这个是默认共享目录,我们把要共享的东西放到目录中。

配置文件 /etc/vsftpd/vsftpd.conf   的修改

anonymous_enable=YES              //默认是允许匿名用户登录,如果改成NO的话,则只允许以ftp服务器本地的用户名的身份登录了

//将这两行的注释去掉,允许匿名用户上传文件
anon_upload_enable=YES            //允许匿名用户上传
anon_mkdir_write_enable=YES       //允许匿名用户写入

使用 lftp 用户登录,默认是匿名用户,共享的是 /var/ftp/pub 目录

 使用 ftp登录,用的是 ftp 用户,共享的是 /var/ftp/pub 目录

当使用服务器端的用户 test 登录时,共享的是 test 用户的家目录

相关文章:Linux文件共享服务之Samba

                 Linux文件共享服务之NFS

猜你喜欢

转载自blog.csdn.net/qq_36119192/article/details/82748360