LINUX下的VSFTPD(转贴)

LINUX下的VSFTPD(转贴)

LINUX下的VSFTPD:


注:转贴,转贴地址:http://zhappytb.blog.163.com/


FTP服务器的21端口用于传输FTP的管理命令,20端口则用于传送数据。在LINXU平台上使用的FTP软件有Wu-ftpd、Proftpd和vsftpd等。Wu-ftpd的历史悠久,是最流行的FTP服务器程序,稳定、出色,但发布较早,安全不及Proftpd及vsftpd。Proftpd在Wu-ftpd之后开发,安全性及稳定性有所提高。而vsftpd则是在Proftpd之后开发的,意为Very Sucure,吸取了Wu-ftpd和Proftpd的优点,安全性、速度、稳定性都有很大提高。





RHEL4(AS)中vsftpd的RPM软件包在第1张光盘中,名为vsftpd-2.0.1-5.i386.rpm。默认情况下没有安装。Vsftpd的主配置文件是/etc/vsftpd.conf。未修改的主配置文件去掉注释后如下(“;”后为解释):





anonymous_enable=YES       ;是否允许匿名访问

local_enable=YES           ;是否允许本地用户登录

write_enable=YES           ;是否允许本地用户写入

local_umask=022            ;生向掩码(文件生成掩码),跟权限有关,我记不住了,有兴趣的朋友可以去查查,知道的朋友也请告诉我一下

dirmessage_enable=YES      ;切换到FTP中的某目录时,是否显示该目录下的隐含文件“.message”

xferlog_enable=YES         ;是否启用启用上传和下载日志

connect_from_port_20=YES   ;是否启用FTP数据端口的连接请求

xferlog_std_format=YES     ;是否让FTP使用ftpd xferlog日志格式

pam_service_name=vsftpd    ;设置PAM认证服务的配置文件,位于/etc/pam.d目录下

userlist_enable=YES        ;需与userlist_file配合使用,稍后介绍

listen=YES                 ;是否处于独立启动模式

tcp_wrappers=YES           ;为YES时,以tcp_wrappers作为主机访问控制方式



(去掉后,vsftpd的配置文件就这么一点^_^。)



/etc/vsftpd.ftpusers保存着不允许进行FTP登录的用户帐户,通常是权限很高的用户,以提高FTP的安全。



至于/etc/vsftpd.user_list文件,里面有说明:



# vsftpd userlist

# If userlist_deny=NO, only allow users in this file

# If userlist_deny=YES (default), never allow users in this file, and

# do not even prompt for a password.

# Note that the default vsftpd pam config also checks /etc/vsftpd.ftpusers

…………(后略)

前面说的userlist_enalbe就跟这有关(重点是第二、三行)



另外,/vsr/ftp是匿名用户的宿主目录.







配置vsftpd的虚拟用户:



1.     建立虚拟用户口令库文件(奇数行为用户名,偶数行为密码):



[root@localhost.localdomain]cat vsftpd

abc

abc12321cba

efg

vsftpd.conf



2. 生成认证文件(db_load生成认证文件,“-f”用于指明虚拟用户的口令库文件,即:vsftpd.操作中,口令库文件名可随便取.“-t hash”指加密方式)



db_load -T -t hash -f vsftpd /etc/vsftpd/vsftpd_login.db

3.设置权限,以提高安全:



chmod 600 /etc/vsftpd/vsftpd_login.db



4. 建立虚拟用户的PAM文件:



cat /etc/pam.d/vsftpd.vu

auth required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd_login

account required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd_login



5.建立虚拟用户的目录,并设置相应权限:



useradd -d /home/vsftpd virtual

chmod 700 /home/vsftpd/



6. 编辑vsftpd的配置文件:



vi /etc/vsftpd/vsftpd.conf

guest_enable=yes

guest_username=virtual

pam_service_name=vsftpd.vu





7. 对虚拟用户设置不同权限:

vi /etc/vsftpd/vsftpd.conf

user_config_dir=/etc/vsftpd_user_conf      ;设置主配置文件

(:wq #保存退出)

mkdri /etc/vsftpd_user_conf

vi /etc/vsftpd_user_conf/abc               ;为虚拟用户配置权限

anon_world_readable_only=no             ;用户可以浏览目录并下载文件

anon_upload_enable=yes                 ;用户可以上传文件

anon_mkdir_write_enable=yes             ;用户可以添加和删除目录

anon_other_write_enable=yes              ;用户可以进行其它操作,如改名、删除文件等。

(:wq)

service vsftpd restart



如果只想让用户下载的话,则配置为:

anon_world_readable_only=no



好了,自个儿看效果吧!!!





常见问题:



1.无法匿名访问?

可能是vsftpd.conf中的anonyoums_enable出的错,或者是你根本就没连接到服务器,也有可能是服务器的iptables出的问题(过滤掉了),这种情况下一般与selinux无关。还有就是服务未运行。



2.创建的虚拟用户无法访问vsftpd?

  原因或许是在创建虚拟用户的时候出的错,如果无法使用虚拟用户访问vsftpd的时候,建议先检查在创建虚拟用户时,打错什么字没有,如果还是没有检查出什么问题来的话,建议你直接推倒重做。还是一点差点忘记说了,就是在创建虚拟用户的时候,尽量将虚拟用户的密码设长一点、复杂一点,我在测试的时候,就是因为密码太短而几次没有成功。



3.在cmd下用虚拟用户登录vsftpd时,出现“200 PORT command successful. Consider using PASV.”的字样是怎么回事啊?

  你所访问的电脑上的防火墙在做怪!!!我就上过这个当!!!



4.其它问题?

  一般情况下,vsftpd出现问题大多数都是因为配置文件出错的,如果想要测试的话,建议在命令行了进行测试,当vsftpd出现问题时,它会在访问端的界面上显示原因。另外不成功的原因是因为服务器上的防火墙没有配置好。











典型vsftpd配置文本样例:



anonymous_enable=yes

local_enable=no

write_enable=yes

local_umask=022

dirmessage_enable=yes

xferlog_enable=yes

connect_from_port_20=yes

xferlog_std_format=yes

pam_service_name=vsftpd

userlist_enalbe=yes

listen=yes

tcp_wrappers=yes

chroot_local_user=yes          ;本地用户登录时将其禁锢在宿主目录中(以免乱窜)

max_clients=100              ;vsftpd的最大客户端连接数为100

max_per_ip=5                ;同一地址的客户机与服务器的最大连接数(防迅雷啊这些软件的)

local_max_rate=500000        ;本地用户最大传输率(KB/S)

anon_max_rate=200000        ;匿名用户最大传输率(KB/S)









抛砖引玉,仅供参考。

(转摘时请标注出处,谢谢!)



(文章错别字难免,希望大家见谅!)

蓝天一号

http://zhappytb.blog.163.com/

2008-04-01
兄弟这个写的更好,只是没有编辑好!!