老鸟止步。

首先还是要搞清楚你自己为甚要搭建vsftp,有了需求就可已按要求进行配置,才会去研究配置文件中的各个参数,来满足自己的实际需要。

一、Linux FTP服务器分类:

<1>wu-ftp

<2>proftp=professionftp

<3>vsftp=verysecurity ftp

我选择的是vsftp

VSFTP是一个基于GPL发布的类Unix系统上使用的FTP服务器软件,它的全称是Very Secure FTP 从此名称可以看出来,编制者的初衷是代码的安全。

 

VSFTP主页中介绍了它以下的9种特点编辑

1、它是一个安全、高速、稳定的FTP服务器;

2、它可以做基于多个IP的虚拟FTP主机服务器;

3、匿名服务设置十分方便;

4、匿名FTP的根目录不需要任何特殊的目录结构,或系统程序或其它的系统文件;

5、不执行任何外部程序,从而减少了安全隐患;

6、支持虚拟用户,并且每个虚拟用户可以具有独立的属性配置;

7、可以设置从inetd中启动,或者独立的FTP服务器两种运行方式;

8、支持两种认证方式(PAPxinetd/ tcp_wrappers);

9、支持带宽限制;

VSFTP市场应用十分广范,很多国际性的大公司和自由开源组织在使用,如:RedHat, SuseDebianOpenBSD

 

初步了解配置文件:

/etc/vsftpd/vsftpd.conf  //主配置文件

/etc/vsftpd.ftpusers     //被禁止登录FTP的用户文件

/etc/vsftpd.user_list    //允许登录FTP的用户文件

二、访问方式

<1>匿名登录

<2>帐号登录

三、配置vsftp服务器

1.vsftpd.conf各项参数说明

#vi/etc/vsftpd/vsftpd.conf

<1>7行:控制匿名登录

      anonymous_enable=YES 改成NO(注释掉和no掉是不同的请自己研究)

<2>local_enable=YES10行:允许本地帐号登录

<3>write_enable=YES13行:控制可写权限

<4>local_umask=02217行:控制本地文件的权限掩码

<5>anon_upload_enable=NO22行:控制是否允许匿名上传(26行同时开启或关闭)

<6>anon_mkdir_write_enable=NO26行:控制是否允许匿名写及创建目录的权限

<7>xferlog_enable=YES33行:控制上传或下载的日志记录

<8>xferlog_file=/var/log/xferlog46行:控制日志的保存路径

<9>idle_session_timeout=60052行:设置指令超时的时间,默认为600

<10>data_connection_timeout=12055行:设置数据连接的超时时间,默认为120

<11>91行:控制登录FTP的用户是否被限制在家目录下;(必须与93行同时开启或关闭)

           chroot_list_enable=YES

<12>93行:登录FTP后被限制在家目录下的用户列表文件

           chroot_list_file=/etc/vsftpd/chroot_list

            /etc /vsftpd/先新建chroot_list文件,内容加入要限制用户的用户名

            没加入限制用户可以访问其目录

<13>ls_recurse_enable=YES99行:控制登录FTP后是否允许ls命令

<14>102:启用/etc/vsftpd/user_list文件

2.配置匿名登录

#vi/etc/vsftpd/vsftpd.conf

7行,设置为: (默认值)

anonymous_enable=YES

启动vsftpd服务器:

#servicevsftpd restart

#serviceiptables stop

匿名登录的默认目录:

/var/ftp/pub

打开匿名上传和写权限:

#vi/etc/vsftpd/vsftp.conf

激活第22

激活第26

 

打开默认共享目录的权限

#chmod777 /var/ftp/pub

 

备注:匿名可以上传下载,但不能删除;

3.本地帐号登录

<1>禁用匿名登入

修改配置文件

#vi/etc/vsftpd/vsftpd.conf

禁用所有匿名控制行,如:

   禁用第7行,第22行,第26行;

<2>开放那些用户可以登入和那些用户拒绝登入

#vi/etc/vsftpd/vsftpd.conf

    102行后,插入如下:

   userlist_deny=NO

      (备注:设置/etc/vsftpd/user_list文件中的用户可登录FTP)

    保存退出

   如果是#userlist_deny=NO 注释掉,则默认全部用户可以登入FTP,当要限某用户不能登入:

    把用户名加入这个文件当中/etc/vsftpd/ftpusers,则这个用户名拒绝登入FTP

     创建用户并加入到相应的控制文件中

     #useradd us1

#useradd us2

     #passwd us1

     #passwd us2

     允许登录到FTP的用户:

      #echo us1>>/etc/vsftpd.user_list

     #echo us2>>/etc/vsftpd.user_list

   

启动FTP服务器:

#servicevsftpd restart

备注:帐号登录FTP,默认是登录在家目录下;

禁止登录到FTP的用户:

#echous3>>/etc/vsftpd.ftpusers

 

<3>将登录后的用户限制在本地家目录下

#vi/etc/vsftpd/vsftpd.conf

激活第91行及第93

  chroot_list_enable=YES

  chroot_list_file=/etc/vsftpd.chroot_list


新建受限用户的列表文件并加入受限用户名

#vi/etc/vsftpd.chroot_list

  us2

保存退出

#servicevsftpd restart

   

<4>限制匿名上传的速度

#vi/etc/vsftpd/vsftpd.conf

:$

  anon_max_rate=5000 //默认以字节为单位 5000表示5K速度

 

<5> 限制本地帐号的上传速度:

     local_max_rate=5000 //(字节/)为单位

 

<6> 针对不同的使用者限制不同的速度(这个速度优先限制所有用户的速度):

    

       #vi /etc/vsftpd/vsftpd.conf   增加下面一行

            user_config_dir=/etc/vsftpd/userconf

 

       #mkdir /etc/vsftpd/userconf   创建一个目录

 

       #vi /etc/vsftpd/userconf/user1   user1是要限制速度的用户名)

 

             local_max_rate=25000

 

<7>定制欢迎信息:

   #vi /etc/vsftpd/vsftpd.conf

       激活80

    ftpd_banner=Welcome to Huayu FTP service.

<8>限制服务器连接数和同IP连接数

1max_clients 
可使用这个参数定义最大的总联机数。超过这个数目将会拒绝联机,0 表示不限。默认值为0

2max_per_ip 
使用这个参数定义每个ip address 所可以联机的数目。超过这个数目将会拒绝联机,0 表示不限。默认值为0

 

      

<9>虚拟FTP用户设置

1        建立虚拟用户口令库文件

#vi /etc/vsftpd/logins.txt

    vuser1

123

vuser2

321

       :wq

       口令库文件中奇数行设置用户名,偶数行设置口令

2        生成vsftpd的认证文件

#db_load -T -t hash -f /etc/vsftpd/logins.txt/etc/vsftpd/vsftpd_login.db ##生成认证文件

3设置认证文件只对root用户可读可写

#chmod 600 /etc/vsftpd/vsftpd_login.db

4、建立虚拟用户所需的PAM配置文件,手工建立vsftpd.vu文件

# cat/etc/pam.d/vsftpd.vu

authrequired /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd_login

account required /lib/security/pam_userdb.sodb=/etc/vsftpd/vsftpd_login

5、建立所有FTP虚拟用户帐号使用的系统用户帐号,并设置该帐号宿主目录的权限

#useradd -d /home/ftpsite -s/sbin/nologin  virtual

#chmod 700 /home/ftpsite

6、设置vsftpd.conf配置文件

#vi/etc/vsftpd/vsftpd.conf

在配置文件中添加虚拟用户的配置内容

guest_enable=YES

guest_username=virtual

pam_service_name=vsftpd.vu(要和刚才建的PAM文件对应)

user_config_dir=/etc/vsftpd/user_config_dir (指定每个虚拟用户账号配置目录,)
local_root=/www 
(这行没有,虚拟用户登入到/ftpsite,这里可以自定义自己的目录,需要在后面创建)

7、配置虚拟用户名的设置

#mkdir -p /etc/vsftpd/user_config_dir (主配置文件对应)
#mkdir -p /www/vuser1   
(创建虚拟用主目录)
#chmod -R 777 /www/vuser1
(设定权限)

#touch /etc/vsftpd/user_config_dir/vuser1 (vuser1权限配置文件)
#echo "anon_world_readable_only=NO
write_enable=YES
anon_upload_enable=YES
anon_other_write_enable=YES
local_root=/www/feixiang
anon_mkdir_write_enable=YES" >/etc/vsftpd/user_config_dir/vuser1

8、重新启动vsftpd服务程序

#service vsftpd restart

现在就应该可以用虚拟帐号登陆了.