搭建linux vsftpd服务器

  一、vsftpd简介

  vsFTPd是一款在Linux发行版中最受推崇的FTP服务器程序;特点是小巧轻快,安全易用;能让其自身特点得发发挥和掌握,也然最主要的是会用;目前在开源操作系统中常用的FTPD套件主要有ProFTPD、PureFTPd和wuftpd等;至于哪个FTP服务器套件更好,哪个是你最熟悉的,哪个就是最好的。

  二、vsftpd的两种工作模式

  FTP的连接一般是有两个连接的,一个是用于客户程和服务器传输命令的,另一个是用于数据传送的连接。FTP服务程序一般会支持两种不同的模式,一种是Port模式,一种是Passive模式(Pasv Mode),我先说说这两种不同模式连接方式的分别。(先假设客户端为C,服务端为S)

  主动模式(Port Mode):命令连接的建立是由客户端C的随机端口向服务端S的TCP 21端口请求连接产生;数据连接的建立是由:(命令端口的连接建立在成功后)客户端C会发送一条命令告诉服务端S(客户端C在本地打开了一个端口随机端口N在等着你进行数据连接),当服务端S收到这个Port命令后,就会利用服务器S自己的TCP 20端口向客户端打开的那个随机端口N进行请求连接,最终连接成功。

  被动模式(Pasv Mode):命令连接的建立也是由客户端C的随机端口向服务端S的TCP 21端口请求连接产生;(命令端口的连接建立在成功后)服务端S会发信息给客户端C,这个信息内容是(服务端S在本地打开了一个高位端口M,你现在去连接我吧),当客户端C收到这个信息后,就利用客户端自己的随机端口向服务端S的M端口进行连接,进而数据连接建立成功。

  三、vsftpd的安装与启动

  Vsftpd的安装程序在RHEL5安装光盘的Server目录中,名称是:vsftpd-*(版本).rpm。在安装之前您可以先查看自己的服务器上是否已经安装。例如下所示:

  #rpm -qa|grep vsftpd

  vsftpd-2.0.5-10.e15

  如果您的服务器上没有安装vsftpd的程序包,您可以使用以下命令安装:

  #rpm -ivh vsftp-2.0.5-10.e15.i386.rpm

  当您的vsftpd程序包安装上之后,就可以设置vsftpd服务开机自动启动。命令如下:

  #chkconfig vsftpd on

  并设置手工启动该服务,命令如下所示:

  #service vsftpd start   或   #/etc/init.d/vsftpd start

  四、vsftpd的用户

  Vsftpd服务支持三种用户登录ftp服务器,包括:匿名用户、本地用户、虚拟用户。

  匿名用户在text模式下,要用用户名ftp,密码也是ftp,来进行登陆;如果是用FTP工具来匿名登陆的话,用户名和密码都为:anonymous。默认情况下匿名用户可以访问和下载,但不能进行上传、删除、新建目录、执行文件等操作!默认情况下匿名用户登录之后访问的位置是/var/ftp目录

  本地用户就是使用useradd手工建立的用户,这些用户的相关资料都存储在/etc/passwd与/etc/shadow文件中。当vsftpd的客户端利用本地用户的身份与口令登录vsftpd时,默认访问本地用户自己的家目录(主目录)。(提示:为了提高vsftpd服务器的安全性,我们可以把一些vsftpd的本地用户的shell设置为/sbin/nologin,表示这些用户不能在本地登录系统,但可以使用ftp的方式访问服务器上的资料)

  虚拟用户:即客户端登录vsftpd服务器时输入的多个用户名在服务器上根本不存在,这些用户名都对应了一个vsftpd服务器上的本地用户。所以当这些虚拟用户在登录时看到的主目录都是相同的位置(就是对应的那个本地用户的家目录)。这样可以提高vsftpd的安装性。

  五、vsftpd的配置文件:

  Vsftpd相关的配置文件有:/etc/vsftpd/vsftpd.conf 、/etc/vsftpd/ftpusers、/etc/vsftpd/user_list三个。其中/etc/vsftpd/ftpusers为ftp黑名单文件,即此文件中存储的用户名都禁止访问vsftpd;/etc/vsftpd/vsftpd.conf是vsftpd的主配置文件;/etc/vsftpd/user_list文件比较灵活,它根据vsftpd.conf主配置文件的不同配置,即可以充当黑名单文件(默认即是),也可以充当白名称文件(即只允许该文件中存储的用户名访问vsftpd),具体设置详见本文相关介绍。

  Vsftpd主配置文件/etc/vsftpd/vsftpd.conf的相关设置:

  anonymous_enable=YES允许使用匿名用户

  anon_upload_enable=YES允许匿名用户上传数据

  anon_mkdir_write_enable=YES允许匿名用户创建目录并在新目录中写入数据

  anon_world_readable_only=NO  允许匿名用户浏览已目录中已经存在的数据

  anon_other_write_enable=YES允许匿名修改、删除文件

  anon_umask=022设置匿名用户上传数据的默认权限

  anon_max_rate=81920匿名用户的最大传输速度(80K/s)

  local_enable=YES允许使用本地用户

  write_enable=YES允许本地用户上传数据

  local_umask=022设置本地用户上传数据的默认权限

  local_max_rate=81920本地用户的最大传输速度(80K/s)

  max_clients=数字允许最大连接客户端数量

  max_per_ip=数字允许每个客户端的最多线程数量

  chroot_local_user=YES         锁定所有本地用户只允许访问自己的家目录

  chroot_list_enable=YES    锁定部分本地用户只允许访问自己的家目录(用户是手工指定的)

  chroot_list_file=/etc/vsftpd.chroot_list  指定锁定用户的列表文件

  userlist_enable=YES允许使用/etc/vsftpd/user_list文件

  userlist_deny=YES            设置/etc/vsftpd/user_list文件中的用户拒绝访问ftp服务器;若为NO

  则是设置只允许user_list文件中的用户访问ftp服务器。

  tcp_wrappers=YES设置允许使用tcp_wrapper来控制vsftpd的访问

  listen_port=21设置ftp服务的端口号默认为21

 

上一篇:安卓防火墙 PS DroidWall

下一篇:学脱壳 -- 脱壳总结小思路