FTP服务器的理论知识可以参考之前的博文:http://yttitan.blog.51cto.com/70821/1178663。
需要强调的是,我们之前用Samba实现的文件服务器只能在局域网内部使用,如果要使互联网中的用户能够下载或上传,那么就多半得使用FTP服务器了。
RHEL6中的FTP功能是由一款名叫vsftpd的软件提供的,名字中的vs是very secure的缩写,所以vsftpd的特点是其安全性和稳定性比较突出。其官方站点为:http://vsftpd.beasts.org/。
系统默认并没有安装vsftpd,我们首先用yum命令安装该服务:
# yum install vsftpd

vsftpd的服务进程名也是vsftpd,启动服务并设为开机自动启动:
# service vsftpd start
# chkconfig vsftpd on


vsftpd的默认主目录是“/var/ftp/”,主配置文件是/etc/vsftpd/vsftpd.conf。配置文件一共有一百多行,配置并不算复杂。
该文件中默认有这样几项设置:
RHEL6.3配置FTP服务器(1) 匿名用户下载和上传_第1张图片

  • “anonymous_enable=YES”表示允许匿名用户访问。vsftpd中的匿名用户有两个:anonymous和ftp,在客户端可以用这两个匿名用户中的任意一个访问服务器。

  • “local_enable=YES”表示允许使用系统用户访问,但是系统用户在访问时默认只能访问自己的主目录,而不是vsftpd的主目录/var/ftp/。

  • “write enable=YES”表示允许写入。这项设置只是一个开关,要使匿名用户或系统用户具有写入权限,还得进行其它的设置。

我们保留默认设置,在FTP默认主目录/var/ftp的pub目录下创建一个测试文件:
# touch /var/ftp/pub/test.txt
然后我们在一台Windows客户端上首先用匿名用户访问测试,
RHEL6.3配置FTP服务器(1) 匿名用户下载和上传_第2张图片

匿名用户可以成功访问,当然前提是要把FTP服务器端的防火墙关闭。


但此时匿名用户却无法上传,原因也很简单,因为匿名用户对/var/ftp/pub目录不具备写入权限:

这里将“/var/ftp/pub”目录的属主改为ftp,即可赋予匿名用户写入权限。
# chown ftp /var/ftp/pub
此时在客户端再次访问,仍然无法写入,这是因为我们还需要对配置文件进行设置。
在配置文件/etc/vsftpd/vsftpd.conf中增加以下几行:

  • “anon_upload_enable=YES”表示允许匿名用户上传。

  • “anon_mkdir_write_enable=YES”表示允许匿名用户创建目录。

  • “anon_umask=022”表示设置匿名用户的umask值。umask值是一种反码的形式,当匿名用户在FTP主目录中创建目录或文件时,目录或文件所具有的默认权限就是由umask值决定的。由于对于目录,我们所能拥有的最大权限是777,对于文件,我们所能拥有的最大权限是666。因为x执行权限对于目录是必须的,没有执行权限就无法进入目录;而对于文件则不必默认赋予x执行权限。所以对于匿名用户创建的目录,默认的权限就是用777减去umask值,即755;对于创建的文件,默认的权限则是用666减去umask值,即644。

  • “anon_max_rate=500000”表示对匿名用户的传输速率进行限制,单位为字节。

修改完成后,重新加载服务:
# service vsftpd reload
这样在客户端再次测试,匿名用户就可以上传了。