Linux搭建FTP详细流程

一、介绍

文件传输协议(File Transfer Protocol,FTP),是一种在互联网中进行文件传输的协议,基于客户端/服务器模式,默认使用 20、21 号端口,其中 20 端口是数据端口用于进行数据传输,21 端口为命令端口,用于接收客户端发出的相关 FTP 命令和参数。FTP 是 C/S 架构,也就是基于客户端/服务器的模式,FTP 服务器是按照 FTP 协议在互联网上提供文件存储和访问服务的主机,FTP 客户端则是向服务器发送连接请求,以建立数据传输链路的主机。

二、工作模式

FTP 协议工作模式有两种:主动模式和被动模式,其中被动模式是默认的工作模式。

主动模式:FTP 服务器主动向客户端发起连接请求。

被动模式:FTP 服务器等待客户端发起连接请求。

三、关闭Selinux和防火墙

复制代码
# 临时关闭selinux
setenforce 0
# 永久关闭selinux
vim /etc/selinux/config
#将SELINUX=enforcing改为SELINUX=disabled,然后保存退出
# 关闭firewalld
systemctl stop firewalld

四、yum安装ftp

复制代码
# 查询是有安装ftp
rpm -qa|grep vsftpd
# 卸载 vsftpd
yum remove vsftpd
# yum安装ftp
yum install -y vsftpd

五、相关检查命令

复制代码
# 查看版本号信息
vsftpd -v
# 查看ftp状态
systemctl status vsftpd.service
# 启动ftp
systemctl start vsftpd.service
# 关闭ftp
systemctl stop vsftpd.service
# 查询端口
ss -anp | grep 21
# 不关闭设置SELinux
getenforce
# 临时关闭开启
setenforce 0/1
# 查看与ftp域相关的策略
getsebool -a | grep ftp
setsebool -P ftpd_full_access on
# 不关闭防火墙的情况下
firewall-cmd --permanent --zone=public --add-service=ftp
firewall-cmd --reload
# 设置开机自启
sudo systemctl enable vsftpd

配置防火墙

确保防火墙允许 FTP 流量。如果使用的是 firewalld:

  1. 允许 FTP 服务

    复制代码
    sudo firewall-cmd --permanent --add-service=ftp
    sudo firewall-cmd --reload

创建虚拟用户环境

为了创建虚拟用户,我们首先需要安装db4-utils包来生成数据库文件,这个文件将用于存储虚拟用户的凭证。

  1. 安装 db4-utils

    复制代码
    sudo yum install db4-utils -y
  2. 创建一个用户列表文件 。例如/etc/vsftpd/virtual_users.txt,格式为每行一个用户名,然后是密码:

    复制代码
    user1
    password1
    user2
    password2
  3. 生成数据库文件

    复制代码
    sudo db_load -T -t hash -f /etc/vsftpd/virtual_users.txt /etc/vsftpd/virtual_users.db
  4. 更改文件权限 以保护用户数据:

    复制代码
    sudo chmod 600 /etc/vsftpd/virtual_users.db

六、虚拟用户环境配置

编辑配置文件/etc/vsftpd/vsftpd.conf来设置虚拟用户的环境。

复制代码
vim /etc/vsftpd/vsftpd.conf

配置 PAM 身份验证

为了使 vsftpd 使用虚拟用户进行身份验证,需要编辑 PAM 配置文件。

  1. 编辑 PAM 文件 /etc/pam.d/vsftpd,添加以下两行:

    注意:如果有问题,则把/etc/pam.d/vsftpd中其他所有的数据删除 再插入这两行

    复制代码
    auth    required        pam_userdb.so db=/etc/vsftpd/virtual_users
    account required        pam_userdb.so db=/etc/vsftpd/virtual_users

基本配置修改

  1. 备份原始配置文件

    bash

    深色版本

    复制代码
    sudo cp /etc/vsftpd/vsftpd.conf /etc/vsftpd/vsftpd.conf.bak
  2. 编辑配置文件 /etc/vsftpd/vsftpd.conf,根据需要调整或添加以下设置:

    深色版本

    复制代码
    anonymous_enable=NO
    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=NO
    listen_ipv6=YES
    
    # 以上为默认 以下为新增
    listen_ipv6=YES
    
    pam_service_name=vsftpd
    userlist_enable=YES
    tcp_wrappers=YES
    
    listen_port=9021
    
    # 使用本地用户作为虚拟用户
    guest_enable=YES
    
    # 指定虚拟用户的用户名
    guest_username=ftpuser
    
    chroot_local_user=YES
    guest_enable=YES
    user_sub_token=$USER
    local_root=/home/ftpuser
    pam_service_name=vsftpd
    user_config_dir=/etc/vsftpd/vsftpd_user_conf
    virtual_use_local_privs=YES
    
    pasv_enable=YES
    pasv_address=132.232.124.126
    pasv_promiscuous=NO
    pasv_min_port=10000
    pasv_max_port=10100
  3. 为每个虚拟用户创建一个目录 ,并将它们指向正确的本地根目录。例如,对于user1,可以这样做:

    复制代码
    sudo mkdir -p /home/ftpuser
    sudo chown nobody:nobody /home/ftpuser
    sudo chmod 777 /home/ftpuser
  4. 可选 :为每个用户创建单独的配置文件,放置在/etc/vsftpd/user_conf目录下。例如,为user1创建配置文件:

    复制代码
    sudo mkdir -p /etc/vsftpd/user_conf
    sudo touch /etc/vsftpd/user_conf/ftpuser
  5. 重启 vsftpd 服务 以应用更改:

    复制代码
    sudo systemctl restart vsftpd
相关推荐
DevSecOps选型指南37 分钟前
2025软件供应链安全最佳实践︱证券DevSecOps下供应链与开源治理实践
网络·安全·web安全·开源·代码审计·软件供应链安全
ABB自动化38 分钟前
for AC500 PLCs 3ADR025003M9903的安全说明
服务器·安全·机器人
努力学习的小廉44 分钟前
深入了解linux系统—— 进程池
linux·运维·服务器
秃头菜狗1 小时前
各个主要目录的功能 / Linux 常见指令
linux·运维·服务器
利刃大大1 小时前
【在线五子棋对战】二、websocket && 服务器搭建
服务器·c++·websocket·网络协议·项目
2301_793102491 小时前
Linux——MySql数据库
linux·数据库
国科安芯2 小时前
抗辐照MCU在卫星载荷电机控制器中的实践探索
网络·嵌入式硬件·硬件工程·智能硬件·空间计算
vfvfb2 小时前
bat批量去掉本文件夹中的文件扩展名
服务器·windows·批处理·删除扩展名·bat技巧
jiunian_cn2 小时前
【Linux】centos软件安装
linux·运维·centos
程序员JerrySUN3 小时前
[特殊字符] 深入理解 Linux 内核进程管理:架构、核心函数与调度机制
java·linux·架构