Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 196|回复: 0

[默认分类] Linux VSFTP服务器详细配置

[复制链接]
  • TA的每日心情
    开心
    2021-12-13 21:45
  • 签到天数: 15 天

    [LV.4]偶尔看看III

    发表于 2018-5-21 14:40:22 | 显示全部楼层 |阅读模式
    Linux VSFTP服务器
    一、Linux FTP服务器分类:
    <1>wu-ftp
    <2>proftp=profession ftp
    <3>vsftp=very security ftp


    配置文件:
    /etc/vsftpd/vsftpd.conf   //主配置文件
    /etc/vsftpd.ftpusers      //被禁止登录FTP的用户文件
    /etc/vsftpd.user_list     //允许登录FTP的用户文件
    二、访问方式
    <1>匿名登录
    <2>帐号登录
    启动FTP服务器:
    #service vsftpd restart

    三、配置vsftp服务器
    1.vsftpd.conf各项参数说明:
    #vi /etc/vsftpd/vsftpd.conf
    <1>第7行: 控制匿名登录
                anonymous_enable=YES 改成NO
    <2>第10行:允许本地帐号登录
    <3>第13行:控制可写权限
    <4>第17行:控制本地文件的权限掩码
    <5>第22行:控制是否允许匿名上传(与26行同时开启或关闭)
    <6>第26行:控制是否允许匿名写及创建目录的权限
    <7>第33行:控制上传或下载的日志记录
    <8>第46行:控制日志的保存路径
    <9>第52行:设置指令超时的时间,默认为600秒
    <10>第55行:设置数据连接的超时时间,默认为120秒
    <11>第91行:控制登录FTP的用户是否被限制在家目录下;(必须与93行同时开启或关闭)
                chroot_list_enable=YES
    <12>第93行:登录FTP后被限制在家目录下的用户列表文件
                chroot_list_file=/etc/vsftpd.chroot_list
                在/etc目录下新建一个vsftpd.chroot_list文件,内容加入要限制用户的用户名
                没加入限制用户可以访问其目录  
    <13>第99行:控制登录FTP后是否允许ls命令
    <14>第102行:启用/etc/vsftpd.user_list文件
    2.配置匿名登录
    #vi /etc/vsftpd/vsftpd.conf
    第7行,设置为: (默认值)
    anonymous_enable=YES
    启动vsftpd服务器:
    #service vsftpd restart
    #service iptables stop
    匿名登录的默认目录:
    /var/ftp/pub
    打开匿名上传和写权限:
    #vi /etc/vsftpd/vsftp.conf
    激活第22行
    激活第26行
      
    打开默认共享目录的权限
    #chmod 777 /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服务器:
    #service vsftpd restart
    备注:帐号登录FTP,默认是登录在家目录下;
    禁止登录到FTP的用户:
    #echo us3>>/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
    保存退出
    #service vsftpd 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连接数
    1、max_clients
    可使用这个参数定义最大的总联机数。超过这个数目将会拒绝联机,0 表示不限。默认值为0。  
    2、max_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
    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、建立所有FTP虚拟用户帐号使用的系统用户帐号,并设置该帐号宿主目录的权限
    # useradd -d /home -s /sbin/nologin /ftpsite 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  
    现在就应该可以用虚拟帐号登陆了.
    <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
    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、建立所有FTP虚拟用户帐号使用的系统用户帐号,并设置该帐号宿主目录的权限
    # useradd -d /home -s /sbin/nologin /ftpsite 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  
    现在就应该可以用虚拟帐号登陆了.
    x
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-5-16 15:24 , Processed in 0.389729 second(s), 37 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表