zoukankan      html  css  js  c++  java
  • 我的linux学习日记day12

    FTP,即:文件传输协议(File Transfer Protocol),基于客户端/服务器模式,默认使用20、21端口号,其中端口20(数据端口)用于进行数据传输,端口21(命令端口)用于接受客户端发出的相关FTP命令与参数。

    FTP协议有以下两种工作模式:

    主动模式(PORT):FTP服务器主动向客户端发起连接请求。
    被动模式(PASV):FTP服务器等待客户端发起连接请求(FTP的默认工作模式)。
    vsftpd是一款运行在Linux操作系统上的FTP服务程序,具有很高的安全性和传输速度。
    vsftpd有以下三种认证模式:

    匿名开放模式:是一种最不安全的认证模式,任何人都可以无需密码验证而直接登陆。
    本地用户模式:是通过Linux系统本地的账户密码信息进行认证的模式,相较于匿名开放模式更安全,而且配置起来简单。
    虚拟用户模式:是这三种模式中最安全的一种认证模式,它需要为FTP服务单独建立用户数据库文件,虚拟出用来进行口令验证的账户信息,而这些账户信息在服务器系统中实际上是不存在的,仅供FTP服务程序进行认证使用。

    安装:

    yum -y install vsftpd
    setsebool -P ftpd_full_access=on

    1、修改配置文件,带注释的是需要修改和新增的配置
    vim /etc/vsftpd/vsftpd.conf

    anonymous_enable=YES   #启用匿名访问模式
    anon_umask=022   #匿名用户上传文件的umask值
    anon_upload_enable=YES   #允许匿名用户上传文件
    anon_mkdir_write_enable=YES   #允许匿名用户创建目录
    anon_other_write_enable=YES   #允许匿名用户重命名、删除等操作
    anon_root=/data/anon   #匿名用户的FTP根目录
    local_enable=YES
    write_enable=YES
    local_umask=022
    dirmessage_enable=YES
    xferlog_enable=YES
    connect_from_port_20=YES
    xferlog_std_format=YES
    listen_port=2231   #vsftpd服务监听的端口号
    listen=NO
    listen_ipv6=YES
    pam_service_name=vsftpd
    userlist_enable=YES
    tcp_wrappers=YES
    pasv_min_port=45000   #PASV模式最小端口号
    pasv_max_port=49000   #PASV模式最大端口号
    mkdir -p /data/anon/pub
    chown -R ftp /data/anon/pub/

    2、创建并授权匿名用户FTP根目录

    3、启动vsftpd服务,并加入开机启动

    systemctl start vsftpd
    systemctl enable vsftpd

    三、本地用户模式

    1、修改配置文件,删除之前的匿名模式配置内容,带注释的是需要修改和新增的配置

    anonymous_enable=NO   #关闭匿名访问模式
    local_enable=YES
    write_enable=YES
    local_umask=022
    local_root=/data/user   #指定本地用户的FTP根目录
    chroot_local_user=YES   #将用户权限禁锢在FTP目录
    allow_writeable_chroot=YES   #允许对FTP根目录执行写入操作
    dirmessage_enable=YES
    xferlog_enable=YES
    connect_from_port_20=YES
    xferlog_std_format=YES
    listen_port=2231
    listen=NO
    listen_ipv6=YES
    pam_service_name=vsftpd
    userlist_enable=YES
    tcp_wrappers=YES
    pasv_min_port=45000
    pasv_max_port=49000

    2、创建本地用户,并指定家目录

    useradd -d /data/user1 -s /sbin/nologin user1
    echo "123456" | passwd --stdin user1

    3、重启vsftpd服务

    systemctl restart vsftpd

    四、虚拟用户模式

    1、创建用于FTP认证的用户数据库文件

    vim /etc/vsftpd/testuser.txt
    test
    123456
    mike
    123456

    2、创建虚拟用户映射的系统本地用户和FTP根目录

    useradd -d /data/ftproot -s /sbin/nologin virtualftp
    chmod -Rf 755 /data/ftproot/

    3、建立用于支持虚拟用户的PAM文件

    vim /etc/pam.d/vsftpd.vu
    
    auth     required     pam_userdb.so  db=/etc/vsftpd/testuser
    account  required     pam_userdb.so  db=/etc/vsftpd/testuser

     4、为两个虚拟用户设置不同的权限,mike拥有所有权限,而test只有读取权限。

    mkdir /etc/vsftpd/testusers_dir
    touch /etc/vsftpd/testusers_dir/test
    vim /etc/vsftpd/testusers_dir/mike
    anon_upload_enable=YES
    anon_mkdir_write_enable=YES
    anon_other_write_enable=YES

    5、修改配置文件,删除之前的匿名模式配置内容,带注释的是需要修改和新增的配置

    anonymous_enable=NO
    anon_umask=022
    local_enable=YES
    guest_enable=YES   #开启虚拟用户模式
    guest_username=virtual   #指定虚拟用户对应的系统用户
    allow_writeable_chroot=YES   #允许对FTP根目录执行写入操作
    write_enable=YES
    local_umask=022
    local_root=/data/ftproot
    dirmessage_enable=YES
    xferlog_enable=YES
    connect_from_port_20=YES
    xferlog_std_format=YES
    listen_port=2231
    listen=NO
    listen_ipv6=YES
    pam_service_name=vsftpd.vu   #指定PAM文件
    userlist_enable=YES
    tcp_wrappers=YES
    user_config_dir=/etc/vsftpd/vusers_dir   #指定虚拟用户配置文件目录
    pasv_min_port=45000
    pasv_max_port=49000

    TFTP

    占用端口号69,UDP协议

  • 相关阅读:
    kernel pwn 入门环境搭建
    linux下sh脚本/bin/bash^M问题解决
    Linux下的C#连接Mysql数据库
    使用docker Hub
    使用ajax+php+mysql实现数据库定时刷新
    docker 安装LAMP环境
    解决Mysql错误:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (111)
    php实现socket简单的例子
    一次mysql调优过程
    一次mysql主从同步问题及解决过程
  • 原文地址:https://www.cnblogs.com/miracle1989/p/12989672.html
Copyright © 2011-2022 走看看