linux怎么弄ftp环境,如何在linux环境下进行ftp搭建

2017-04-17 回答

在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出现问题时,它会在访问端的界面上显示原因。另外不成功的原因是因为服务器上的防火墙没有配置好。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值