FTP服务器安装、远程访问以及安全配置项

一、安装ftp

1、首先,确保您的系统已经更新到最新的软件包版本。运行以下命令来更新软件包列表并安装更新的软件包:

bash 复制代码
sudo yum update

2、安装vsftpd服务器软件包:

bash 复制代码
sudo yum install vsftpd

3、安装完成后,启动vsftpd服务并将其设置为在系统引导时自动启动:

bash 复制代码
sudo systemctl start vsftpd
sudo systemctl enable vsftpd

4、(如果有防火墙)您还需要配置防火墙以允许FTP流量通过,默认情况下,FTP使用端口21和一些被动模式数据端口。运行以下命令来打开这些端口:

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

二、远程访问配置

  1. 确认FTP服务器已安装并运行:按照上面的说明安装并启动了vsftpd服务。

  2. 打开防火墙端口:默认情况下,FTP服务器使用端口21来控制连接,以及一些被动模式数据端口(通常在范围50000-51000)。您需要打开这些端口,以便允许远程客户端连接。使用以下命令打开端口:

    bash 复制代码
    sudo firewall-cmd --permanent --add-port=21/tcp
    sudo firewall-cmd --permanent --add-port=50000-51000/tcp
    sudo firewall-cmd --reload
  3. 配置vsftpd :编辑/etc/vsftpd/vsftpd.conf文件来配置vsftpd以允许远程访问。打开终端并运行以下命令来编辑文件:

    bash 复制代码
    sudo nano /etc/vsftpd/vsftpd.conf

    您可以根据需要进行以下配置更改:

    • 允许匿名访问(不建议):将anonymous_enable设置为YES。

    • 允许本地用户登录:确保local_enable设置为YES。

    • 设置本地用户的主目录:默认情况下,用户将被限制在其家目录中。如果您想要更灵活的配置,请考虑修改chroot_local_userlocal_root选项。

    • 启用本地用户上传文件:将write_enable设置为YES。

    • 启用被动模式:确保pasv_enable设置为YES,并在pasv_min_portpasv_max_port中指定被动模式端口范围(例如50000-51000)。

    保存并关闭文件。

  4. 重新启动vsftpd服务:使配置更改生效:

    bash 复制代码
    sudo systemctl restart vsftpd
  5. 创建FTP用户 :如果您打算允许本地用户访问FTP服务器,请确保这些用户存在,并且他们具有适当的权限。您可以使用useradd命令创建用户,然后使用passwd命令为他们设置密码。

  6. 测试远程访问 :使用FTP客户端(如FileZilla)或命令行中的ftp命令来测试远程访问。使用FTP客户端时,请确保指定正确的主机名或IP地址、端口、用户名和密码。

三、vsftpd.conf 安全配置方法

配置vsftpd.conf文件以提高FTP服务器的安全性是非常重要的。以下是一些安全配置选项,可以帮助您确保FTP服务器的安全性:

  1. 禁用匿名访问:确保匿名访问被禁用,以防止未经授权的访问。

    bash 复制代码
    anonymous_enable=NO
  2. 启用本地用户登录:允许本地用户登录FTP服务器。

    bash 复制代码
    confCopy codelocal_enable=YES
  3. 限制用户的根目录 :通过chroot_local_user选项,将用户锁定在其家目录中,以防止他们访问系统的其他部分。

    bash 复制代码
    chroot_local_user=YES
  4. 限制用户上传权限:限制用户上传文件的权限。

    bash 复制代码
    write_enable=YES
  5. 限制用户的命令 :通过cmds_allowed选项限制用户可以执行的FTP命令。

    bash 复制代码
    cmds_allowed=USER,PASS,QUIT,PORT,PASV,LIST,SITE_CHMOD
  6. 启用防火墙支持:如果您使用防火墙,请启用防火墙支持以使FTP服务器能够工作。

    bash 复制代码
    pasv_enable=YES
    pasv_min_port=40000
    pasv_max_port=40100
    pasv_address=<Your_Public_IP_Address>

    这里,pasv_min_portpasv_max_port定义了被动模式使用的端口范围,pasv_address是FTP服务器的公共IP地址。

  7. 启用SSL/TLS加密:为了安全传输数据,您可以启用SSL/TLS加密。首先,生成SSL证书,然后配置以下选项:

    bash 复制代码
    ssl_enable=YES
    allow_anon_ssl=NO
    force_local_data_ssl=YES
    force_local_logins_ssl=YES
    ssl_tlsv1=YES
    ssl_sslv2=NO
    ssl_sslv3=NO
    ssl_ciphers=HIGH
    rsa_cert_file=/etc/ssl/private/vsftpd.pem

    请确保将rsa_cert_file设置为您的SSL证书的正确路径。

  8. 限制登录尝试次数 :通过max_login_attempts选项,限制登录尝试的次数,以防止暴力破解攻击。

    bash 复制代码
    max_login_attempts=3
  9. 禁用不必要的FTP功能 :根据需要禁用不必要的FTP功能,以减少潜在的攻击面。可以通过设置选项来实现这一点,例如,禁用SITE EXEC

    bash 复制代码
    cmds_denied=SITE EXEC
  10. 日志记录:启用详细的日志记录以监视FTP服务器的活动。将日志文件设置为只读以增加安全性。

    bash 复制代码
    xferlog_enable=YES
    xferlog_std_format=NO
    log_ftp_protocol=YES
    ls_recurse_enable=YES
    ascii_upload_enable=YES
    ascii_download_enable=YES
    deny_email_enable=YES
相关推荐
萨格拉斯救世主40 分钟前
戴尔R930服务器增加 Intel X710-DA2双万兆光口含模块
运维·服务器
无所谓จุ๊บ41 分钟前
树莓派开发相关知识十 -小试服务器
服务器·网络·树莓派
Jtti43 分钟前
Windows系统服务器怎么设置远程连接?详细步骤
运维·服务器·windows
TeYiToKu1 小时前
笔记整理—linux驱动开发部分(9)framebuffer驱动框架
linux·c语言·arm开发·驱动开发·笔记·嵌入式硬件·arm
dsywws1 小时前
Linux学习笔记之时间日期和查找和解压缩指令
linux·笔记·学习
yeyuningzi1 小时前
Debian 12环境里部署nginx步骤记录
linux·运维·服务器
上辈子杀猪这辈子学IT1 小时前
【Zookeeper集群搭建】安装zookeeper、zookeeper集群配置、zookeeper启动与关闭、zookeeper的shell命令操作
linux·hadoop·zookeeper·centos·debian
minihuabei1 小时前
linux centos 安装redis
linux·redis·centos
EasyCVR2 小时前
萤石设备视频接入平台EasyCVR多品牌摄像机视频平台海康ehome平台(ISUP)接入EasyCVR不在线如何排查?
运维·服务器·网络·人工智能·ffmpeg·音视频
lldhsds2 小时前
书生大模型实战营第四期-入门岛-1. Linux前置基础
linux