linuxvsftp配置:Linux操作系统配置Vsftp思路方法

Linux下vsftp重新安装和配置虚拟用户


重新安装和配置虚拟用户


以下都是在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

 

Tags:  vsftp配置 linux启动vsftp linuxvsftp linuxvsftp配置

延伸阅读

最新评论

发表评论