Linux网络服务04——FTP文件传输服务

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux网络服务04——FTP文件传输服务相关的知识,希望对你有一定的参考价值。

Linux网络服务04——FTP文件传输服务

一、FTP连接及传输模式

1、控制连接:TCP 21,用于发送FTP命令信息

2、数据连接:TCP 20,用于上传、下载数据

3、数据连接的建立类型:

1)主动模式:服务器主动发起数据连接

首先由客户端向服务端的21端口建立FTP控制连接。当需要传输数据时,客户端以PORT命令告知服务器“我打开了某端口,你过来连接我”,预算服务器从20端口向客户端的该端口发送请求并建立数据连接。

2)被动模式:服务器被动等待数据连接

如果客户端所在网络的防火墙禁止主动模式连接,通常会使用被动模式。

首先由客户端想服务器的21端口建立FTP控制连接。当需要传输数据时,服务器以PASV命令告知客户端“我打开了某端口,你过来连接我”,于是客户端向服务器的该端口(非20)发送请求并建立数据连接。

4、传输模式

在传输文件时,根据是否进行字符转换,分为文本模式和二进制模式。

1)文本模式:又称ASCIIAmerican Standard Code for Information Interchange)美国信息交换标准码模式,这种模式在传输文件时使用ASCII标准字符序列,一般只用于纯文本文件的传输。

2)二进制模式:又称Binary模式,这种模式不会转换文件中的字符序列,更适合传输程序、图片等非纯文本字符的文件。

使用二进制模式比文本模式更有效率,大多数FTP客户端工具可以根据文件类型自动选择文件传输模式。

FTP用户类型

1、匿名用户:用户名为ftpanonymous,提供任意密码(包括空密码)都可以通过服务器的验证。一般用于公共文件的下载,如提供一些免费的软件、学习资料下载的站点。

2、本地用户:直接使用本地的系统用户账号进行验证。

3、虚拟用户:通过一份独立的用户数据库文件进行登录验证,将FTP账户与Linux系统账户的关联性将至最低,为系统提供更好的安全性。

三、FTP服务器软件的种类

1Windows系统:FileZilla ServerServ-U

2Linux/Unix系统:vsftpdVery Secure FTP Daemon

FTP客户端工具的种类

1Windows系统:ftp命令、CuteFTPFlashFXPLeapFTPFilezilla等。还有一些下载工具软件,如FlashGetWget等,但不具备上传功能,通常不称为FTP客户端工具。

2Linux/Unix系统:ftp命令

搭建匿名访问的FTP服务

1、安装FTP服务软件

 技术分享

2、准备匿名FTP访问的目录

 技术分享

 

3、开放匿名用户配置并启动vsftpd服务

 

 技术分享

技术分享

技术分享

 

 

4、测试匿名FTP服务器

在客户端安装FTP客户端

 

 技术分享

技术分享

技术分享

技术分享

 

 

测试小结:匿名用户具有新建目录、上传文件、删除文件的权限,新建目录默认权限755,上传文件默认权限644

 

搭建本地用户验证的FTP服务

1、创建本地用户

 技术分享

2、修改配置文件,重启FTP服务。

 技术分享

技术分享

技术分享

技术分享

 

客户端测试

 

 技术分享

技术分享技术分享

 

测试小结:本地用户具有新建目录、上传文件的权限,新建目录默认权限700,上传文件默认权限600

 

3ftpusersuser_list用户列表的使用

1ftpusers文件:FTP服务器中的黑名单,优先级高于user_list文件

2user_list文件:此用户列表默认情况下也是黑名单,即在此用户列表中的用户不可访问FTP服务器,但可以通过vsftpd.conf主配置文件的修改将此名单改为白名单,且仅此名单中的用户可以访问。

3)示例:

1>test1用户放入ftpusers文件中,其他配置文件不修改,尝试用test1用户登录

技术分享

客户测试

技术分享 

2>test1移除出ftpusers文件,将test2放入user_list用户列表中,先用默认的配 置文件,在客户端尝试用test2访问FTP服务器。在修改配置文件,将user_list改为白 名单,再在客户端分别用test1test2尝试访问。 

 技术分享

技术分享

技术分享

客户端测试

技术分享 

服务器修改主配置文件,重启服务

[[email protected] vsftpd]# vim vsftpd.conf

技术分享

技术分享 

 

客户端再次测试

技术分享 

测试小结:配置文件中默认user_list用户列表为黑名单即默认为userlist_deny=YES,当增加userlist_deny=NO时,user_list用户列表为白名单,此时仅此名单内用户可访问FTP服务器。

 

搭建虚拟用户验证的FTP服务

1、建立虚拟用户账号数据库

vsftpd服务使用Berkeley DB格式的数据库文件来存放虚拟用户账号,使用db_load工具生成数据库文件。(若未安装,安装包在安装光盘1中,软件名为db4-utils

技术分享 

 

注:db_load命令

-T:允许非Berkeley的程序使用该数据库

-t:指定算法 (hash:哈希,散列)

-f:指定源文件

注意:生成的数据库文件必须为.db”格式

 技术分享

 

2、添加虚拟映射账号,为FTP根目录修改权限

技术分享 

 

3、增加PAM认证

技术分享 

 

 

4、修改vsftpd.conf配置文件,重启服务

技术分享

技术分享

技术分享

5、客户端测试

 

6、实现每个虚拟用户不同根目录、不同权限的管控

1)创建用户控制目录,并创建虚拟所对应的同名配置文件

 技术分享

修改zhangsan的配置文件,使其可以上传、建立目录、删除文件、重命名文件、最大传输速率1字节/秒、根目录为/var/zhangsan技术分享 

技术分享

 

修改lisi的配置文件,使其仅可以下载上传,不开放其他权限,不限制传输速率,根目录为/var/lisi

技术分享 

wangwu的配置文件不做修改,其权限为配置文件中的默认权限,根目录为/var/ftproot,仅可以下载,无法上传。

 技术分享

2)修改vsftpd.conf主配置文件,重启服务

[[email protected] vsftpd]# vim vsftpd.conf

技术分享

技术分享 

 

 

 

 

3)客户端测试

验证zhangsan

 技术分享

技术分享

 

验证lisi

 技术分享

验证wangwu

 技术分享

 

【课外知识】建立vsftpd服务的日志文件。

 技术分享

技术分享技术分享

 

 

 

 

 

其他配置:

listen=YES

listen_address=192.168.1.108

listen_port=2121 //设置监听端口

pasv_enable=YES //是否开启被动模式

pasv_min_port=24500 //被动模式端口下限

pasv_max_port=24600 //被动模式端口上限

max_clients=2000 //最大15000,最大客户连接数,一般不限制

max_per_ip=2 //每个ip限制最多打开几个客户端工具,一般不限制

anon_max_rate=50000 //匿名最大传输速率,一般不限制

local_max_rate=20000 //本地用户最大传输速率,一般不限制

以上是关于Linux网络服务04——FTP文件传输服务的主要内容,如果未能解决你的问题,请参考以下文章

Linux中FTP的一点理解

FTP文件传输原理

linux怎么搭建ftp服务器

Windows和Linux文件共享的几种方式

Linux网络服务——FTP服务器搭建

linux网络文件共享服务的实现