​文件共享服务之FTP

文件共享服务之FTP

一、什么是文件共享服务

简单理解就是文件或存储块设备可以共享给大家使用。
 1、实现共享服务有三种!

  • (1)ftp:属于应用层服务,可以跨平台使用(linux<--->uinx<--->windows)

  • (2)nfs:属于内核模式,不可跨平台(linux<--->linux)

  • (3)samba:可跨平台(linux<--->uinx<--->windows)

2、实现存储设备与服务器连接方式有三种!

  • (1)DAS:简单说就是连接的磁盘

  • (2)NAS:通过nfs/CIFS协议实现网络共享文件(文件存储方式)电子邮件、网页服务器、多媒体流服务、档案分享等就适用于NAS存储架构

  • (3)SAN:通过网线或光纤实现iscsi和FCSAN将物理存储设备连接起来使用(块存储方式较底层,需要格式化并挂载当本地磁盘使用)数据库有关的应用适用于SAN存储架构

3、附:

  • (1) nfs(Network File System,网络文件系统)协议实现linux的文件封装共享传输。

  • (2)CIFS(Common Internet File System,公共互联网文件系统)协议实现windows与linux的共享识别,例如samba就是基于CIFS(SMB)协议实现。

二、FTP

ftp:File Transfer Protocol
 应用层协议:tcp,21端口
 C/S架构
 命令链接21(长链接)
 数据链接20(传完断开在传在链接)
 数据传输格式

  • 文本传输(不应该人为干预,原文件是什么格式就用什么格式传输)

  • 二进制传输(不应该人为干预,原文件是什么格式就用什么格式传输)

主动ftp模式

  • 主动:由服务器创建连接
     命令:
     Client:50000 –> Server: 21
     数据:
     Server: 20/tcp –> Client: 50000+1

被动ftp模式

  • 被动:由客户端创建连接
     命令:
     Client:50000 –> Server: 21
     数据:
     Client:50000+1 –> Server: 随机端口

三、响应码

1xx: 信息
 2xx: 成功类的状态码
 3xx: 提示需进一步提供补充类信息的状态码
 4xx: 客户端错误
 5xx: 服务端错误

四、FTP存储和mysql存储有什么不同?

FTP属于非结构化数据存储,无法定义类型关系等,包括图片文件,二进制文件等
 mysql属于结构化关系数据库存储,表列对应关系,可定义type及字符长度。

五、用户认证

1、虚拟用户:

  • 用于访问某个服务的用户(mysql用户,http网站用户)和操作系统上的用户没有关系,这样做是为了安全

  • FTP默认是系统账户,为了系统安全,可以改成虚拟用户登录

  • 虚拟用户可以基于文件(非系统用户的文件),也可以基于链接mysql数据实现FTP的认证登录

  • nsswitch: network server switch, 名称解析框架
      配置文件:/etc/nsswitch.conf
     模块:/lib64/libnss*, /usr/lib64/libnss*

  • pam: pluggable authentication module, 用户认证框架
     模块:/lib64/security/
     配置文件:/etc/pam.conf, /etc/pam.d/*

  • 以上两种框架linux自带框架,通过库调用的方式自由选择基于系统账户实现,非系统账户实现,还是数据库账户形式实现不用全部编译进去浪费资源。

2、系统用户
 3、匿名用户
 总结:匿名用户或虚拟用户虽然和系统用户没有关系,但是登陆后获取系统上的文件权限还是需要映射为系统用户,以系统用户的权限访问系统文件(例如:ftp系统用户,httpd系统用户)

六、FTP安装与配置

2016-04-13_005914.png  

  • 配置文件
             用户认证配置文件:/etc/pam.d/vsftpd
             服务脚本:/etc/rc.d/init.d/vsftpd
             
             置文件:/etc/vsftpd/vsftpd.conf
             匿名用户配置:
             anonymous_enable=YES
             anon_upload_enable=YES
             anon_mkdir_write_enable=YES
             anon_ohter_write_enable=YES
             系统用户的配置:
             local_enable=YES
             write_enable=YES
             local_umask=022
             禁锢所有的ftp本地用户于其家目录中:
             chroot_local_user=YES
             禁锢文件中指定的ftp本地用户于其家目录中:
             chroot_list_enable=YES
             chroot_list_file=/etc/vsftpd/chroot_list(在此文件中添加系统用户)
             虚拟用户映射系统用户
             guest_enable=YES
             guest_username=vuser
             通过pam用户认证
             pam_service_name=vsftpd
             vsftpd在/etc/pam.d/vsftpd
     

             匿名用户(映射为ftp用户)共享资源位置:/var/ftp
             系统用户通过ftp访问的资源的位置:用户自己的家目录
             虚拟用户通过ftp访问的资源的位置:给虚拟用户指定的映射成为的系统用户的家目录

原创文章,作者:Net18-糖糖,如若转载,请注明出处:http://www.178linux.com/14909

(0)
Net18-糖糖Net18-糖糖
上一篇 2016-04-18 00:15
下一篇 2016-04-18 00:48

相关推荐

  • tomcat

    编程语言: 硬件级:微码编程,汇编语言 系统级:C,C++,… 应用级:Java, PHP, Python, Ruby, Perl, C#, … 程序:指令+数据 过程式编程:以指令为中心,数据服务于代码; 对象式编程:以数据为中心,指令服务于数据; java Java代码的运行:*.java(source code) –…

    Linux干货 2017-07-03
  • http状态码大全

    状态值:100 客户端应当继续发送请求。这个临时响应是用来通知客户端它的部分请求已经被服务器接收,且仍未被拒绝。客户端应当继续发送请求的剩余部分,或者如果请求已经完成,忽略这个响应。服务器必须在请求完成后向客户端发送一个最终响应。 状态值:101 服务器已经理解了客户端的请求,并将通过Upgrade 消息头通知客户端采用不同的协议来完成这个请求。在发送完这个…

    Linux干货 2016-11-01
  • 马哥教育N22期第五周作业

    1、显示当前系统上root、fedora或user1用户的默认shell; [root@localhost ~]# egrep "^root|fedora|user1" /etc/passwd root:x:0:0:root:/root:/bin/bash fedora:x:1002:1002::/…

    Linux干货 2016-09-15
  • 网络班21期第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。          mkdir /home/tuser1        &n…

    Linux干货 2016-08-22
  • 用户、组及其管理

    用户和组管理    Linux是一个多用户、多任务的操作系统。多用户、多任务就是可以在系统上建立多个用户,多个用户可以在同一时间内登录同一台主机的系统执行不同的任务,而互不影响。例如某台linux服务器上有4个用户,分别是root、www、ftp和mysql,在同一时间内root用户可能在管理维护系统,www用户可能在修改自己的程序和操作…

    Linux干货 2016-08-04
  • 实战演练su命令与sudo服务

    su和su- 切换方式 实例: sudo 提权 sudo的特色功能 sudo命令的常用参数 注意 案例1——允许zhanghe用户执行所有命令: 案例2——仅允许linuxprobe用户以root用户身份执行cat命令。 案例3——允许linuxprobe用户以任意身份执行命令,且每次都不需要密码验证。 su命令与sudo服务 在工作生产环境中不要去使用ro…

    Linux干货 2016-09-05