位置:海鸟网 > IT > linux/Unix >

在Linux系统下配置WU-FTP服务器

在众多的网络应用中,FTP(FileTransferporotocol)有着非常重要的地位。在Internet中一个十分重要的资源就是软件资源。而各种各样的软件资源大多数都是放在FTP服务器中的。可以说,FTP与WEB服务几乎占据了整个Internet应用的80%以上。

FTP服务可以根据服务对象的不同分为两类:一类是系统FTP服务器,它只允许系统上的合法用户使用;另一类是匿名FTP服务器,AnonymousFTPServer,它使用任何人都可以登录到FTP服务器上去获取文件。

一、选择和安装FTP服务器软件

如果你在安装LINUX系统的时候,在选择启动进程的时候选择了“ftpd”这一项的话,安装完LINUX系统后,它已经将一个默认的FTP服务器安装到系统中去了。我们已经可以利用它来实现系统FTP服务器的功能了。我们只需在此基础上根据我们的需要进行一些个性化设定就可以了。

在绝大多数的LINUX发行版本中都选用的是WashingtonUniversityFTP,它是一个著名的FTP服务器软件,一般简称为wu-ftp。它功能强大,能够很好地运行于众多的UNIX操作系统,例如:ibmAIX、FreeBSD、hp-UX、NeXTstep、Dynix、SunOS、Solaris等。所以Internet上的FTP服务器,一大半以上采用了它。wu-ftp拥有许多强大的功能,很适于吞吐量较大的FTP服务器的管理要求:

1)可以在用户下载文件的同时对文件做自动的压缩或解压缩操作;

2)可以对不同网络上的机器做不同的存取限制;

3)可以记录文件上载和下载时间;

4)可以显示传输时的相关信息,方便用户及时了解目前的传输动态;

5)可以设置最大连接数,提高了效率,有效地控制了负载。
二、wu-ftp的组成

安装了wu-ftp后,你将在/bin目录下看到以下五个可执行文件:

ftpdFTP服务器程序

ftpshut用于关闭FTP服务器程序

ftpcount显示目前在线人数

ftpwho查看目前FTP服务器的连接情况

ckconfig检查FTP服务器的设置是否正确

除了这些可执行文件以外,它还在/etc和/var目录下生成了七个配置文件:

/etc/ftpusers

/etc/ftpaccess

/var/run/ftp.pids

/etc/ftpconversions

/var/log/xferlog

/etc/ftpgroups

/etc/ftphosts

系统安装了wu-ftp后,会建立一个特殊的用户ftp,并在/home目录下建立了一个ftpd目录,当用户以匿名登录上来时,将会自动定位于这个目录下。在这个目录下一般会建立几个子目录。/home/ftpd/bin存放一些供FTP用户使用的可执行文件

/home/ftpd/etc存放一些供FTP用户使用的配置文件

/home/ftpd/pub存放供下载的信息

/home/ftpd/incoming存放供上载信息的空间
三、wu-ftp的配置

1.查看、修改/etc/inetd.conf文件

/etc/inetd.conf文件是LINUX系统的超级服务器inetd的配置文件。它负责监听多个TCP/IP端口。当它收到请求,就根据配置文件派生一个相应的服务器。通过使用超级服务器,其他服务就可以只在需要时才派生,从而大大节省了系统资源。而wu-ftp就是利用超极服务器inetd来监听请求的。当超级服务器inetd收到了客户端的FTP请求时,就根据配置文件打开一个FTP服务进程。所以我们如果要使用wu-ftp,就必须确认在超级服务器inetd的配置文件inetd.conf中有这样一句:

ftpstreamtcpnowaitroot/usr/sbin/tcpdwu.ftpd以便当超级服务器收到FTP请求的时候,能够派生一个wu-ftp的FTP服务进程。(注:要确认是否有这样一行时,可以使用文件内容查找命令来确认:cat/etc/inetd.conf grepftp如果没有,则用手工加入或手工修改。)

2.wu-ftpd的命令选项wu-ftpd就是wu-ftp的服务进程。它可以不带参数执行,也可以带参数执行。下面简单介绍一下wu-ftpd的执行参数。

-d当FTP服务器出错时,将错误入系统的syslog中;

-l将每次FTP客户端进行连接的入系统的syslog中;

-t设置FTP客户端连接几分钟无操作就切断连接;

-a使wu-ftp使用/etc/ftpaccess的设定;

-A使wu-ftp不使用/etc/ftpaccess的设定;

-L将FTP客户端连线后所执行的程序记录在系统的syslog中;

-I将FTP客户端上载文件的日志记录在/usr/adm.xferlog文件中;

-o将FTP客户端下载文件的日志记录在/usr/adm/xferlog文件中。

通过对以上参数的理解,我们建议,将上面系统安装时的那条默认配置改为:ftpstreamtcpnowaitroot/usr/sbin/tcpdwu.ftpd–a–I

3.提供自动压缩、解压缩的功能

如果想让FTP服务器有自动压缩、解压缩的功能,必须先将一些压缩、解压缩的命令文件如tar、gzip、gunzip、compress、uncompress等命令文件拷贝到/home/ftpd/bin目录下。 

4.关于/etc/ftpaccess的设置

这个配置文件是FTP服务器上最重要的配置文件,它直接关系到你的FTP服务器能否正常工作,还有许多权限上的设置。下面是一个典型的配置实例。

loginfails3

classlocalreal*

classremoteanonymousguest*

limitremote100Any/etc/ftpd/toomany.msg

message/etc/ftpd/welcome.msglogin

compressyeslocalremote

taryeslocalremote

privateyes

passwd-checkrfc822warn

logcoMMandsreal

logtransferanonymousguestinboundoutbound

logtransferrealinbound

shutdown/etc/ftpd/shut.msg

deletenoanonymous,guest

overwritenoanonymous,guest

renamenoanonymous

chmodnoanonymous,guest

umasknoanonymous

upload/home/ftpd*no

upload/home/ftpd/binno

upload/home/ftpd/etcno

upload/home/ftpd/pubyesreal0644dirs

upload/home/ftpd/incomingyesrealguestanonymous0644dirs

aliasin/incoming

emailguest@xxx.net

emailguest@yyy.net

deny*.com.tw/etc/ftpd/deny.msg