重新安装和配置虚拟用户
以下都是在root用户下进行
#tar zxvf vsftpd-2.0.5.tar.gz --解压
#cd vsftpd-2.0.5.tar.gz --解压后进入vsftpd-2.0.5.tar.gz目录
# mkdir /usr/share/empty/ --VSFTPD默认设置需要个空目录:/usr/share/empty
# mkdir /var/ftp/ --如果容许匿名用户(anonymous)那么你将需要个"ftp"用户和其home目录(这个home目录不属于“ftp”用户而且“ftp"用户也对其没有写权限)在你系统中存在
#adduser 然后回车,依照介绍说明来添加两个用户"nobody" 和"ftp" ,'nobody'般都已经存在来,如果添加时提示用户已经存在,就不用添了. 'ftp'用户设置时主目录都设在/var/ftp
#chmod 755 /var/ftp --把/var/ftp目录权限设为drwxr-xr-x
#make
#make
#cp vsftpd.conf /etc --"make "不会拷贝默认配置文件所以手工拷贝过去.区别系统位置可能不样,看下,如果有/etc/vsftp目录话,就拷贝到/etc/vsftp下
安装完成.
测试下:
编辑/etc/vsftpd.conf, 在最下面加入以下这行:
listen=YES
确定你没有运行其他FTP服务(否则VSFTPD不能占用FTP所需21端口)
# /usr/local/sbin/vsftpd &
[1] 306
如果切正常那么你将连上FTP服务器
#ftp localhost
Connected to localhost (127.0.0.1).
220 (vsFTPd 2.0.1)
Name : ftp
331 Please specy the password.
Password:
230 Login successful. Have fun.
Remote system type is UNIX.
Using binary mode to transfer files.
ftp>
运行方式:
VSFTPD能运行在独立模式(standalone)或者通过inetd来启动
独立模式(standalone)就是前面测试时用思路方法,在vsftpd.conf加入"listen=YES"
用xinetd服务启动
请在/etc/xinetd.d/vsftpd
service ftp
{
_type = stream
wait = no
user = root
server = /usr/local/sbin/vsftpd
# server_args =
# log_on_success DURATION USERID
# log_on_failure USERID
nice = 10
disable = no
}
配置vsftp
修改/etc/vsftpd.conf,
vsftpd.conf比较简单,有很多选项没有列出来,具体可以看blog里另外篇.
有几个可能会比较常用到但是不在vsftpd.conf中列在下面:
让vsFTP最大支持链接数为100个每个IP最多能支持5个链接所以我应该在vsftpd.conf中加上如下两行:
max_clients=100
max_per_ip=5
anon_max_rate=数字 ----这是匿名下载速度
local_max_rate=数字 ---这是vsFTP服务器上普通用户下载速度
注:这个数字单位是字节所以我们要计算下比如我想让匿名用户和vsFTP上用户都以100KB下载所以这个数字应该是1024x100=102400 所以我们要在vsftpd.conf中加入下面两行 :
anon_max_rate=102400
local_max_rate=102400
目录介绍说明:
在vsftpd.cof文件中,有 dirmessage_enable=YES然后在目录中建个文件 " .message " 在文件中写上有关目录介绍说明就可以了.
配置vsftp 虚拟用户
1.生成虚拟用户口令库文件为了建立此口令库文件先要生成个文本文件该文件格式如下单数行为用户名偶数行为口令:
#vi account.txt
ylg
1234
zhanghong
4321
gou
5678
2.生成口令库文件并修改其权限:
#db_load -T -t hash -f ./account.txt /etc/account.db
#chmod 600 /etc/account.db
3.新建个虚拟用户PAM文件加上如下两行内容:
#vi /etc/pam.d/vsftp.vu
auth required /lib/security/pam_userdb.so db=/etc/account
account required /lib/security/pam_userdb.so db=/etc/account
4.建立虚拟用户设置该用户所要访问目录并设置虚拟用户访问权限:
#useradd -d /ftpsite virtual_user
#chmod 700 /ftpsite
经过该步骤设置/ftpsite就是virtual_user用户主目录该用户也是/ftpsite目录拥有者除root用户的外只有该用户具有对该目录读、写和执行权限
5.生成个测试文件先切换至virtual_user用户身份然后在/ftpsite目录下创建个文件:
#su -virtual_user
$vi /ftpsite/mytest
This is a test file.
$su - root
6.编辑/etc/vsftpd.conf文件使其整个文件内容如下所示(去掉了注释内容):
anonymous_enable=NO
local_enable=YES
local_umask=022
xferlog_enable=YES
connect_from_port_20=YES
xferlog_std_format=YES
listen=YES
write_enable=YES
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_other_write_enable=YES
one_process_model=NO
chroot_local_user=YES
ftpd_banner=Welcom to my FTP server.
anon_world_readable_only=NO
guest_enable=YES
guest_username=virtual_user
pam_service_name=vsftp.vu
上面代码中guest_enable=YES表示启用虚拟用户;guest_username=virtual则是将虚拟用户映射为本地用户这样虚拟用户登录后才能进入本地用户virtual目录/ftpsite;pam_service_name=vsftp.vu指定PAM配置文件为vsftp.vu
最新评论