云计算百科
云计算领域专业知识百科平台

HoRain云--CentOS7搭建安全SFTP服务器全攻略

  

🎬 HoRain云小助手:个人主页

 🔥 个人专栏: 《Linux 系列教程》《c语言教程》

⛺️生活的理想,就是为了理想的生活!


⛳️ 推荐

前些天发现了一个超棒的服务器购买网站,性价比超高,大内存超划算!忍不住分享一下给大家。点击跳转到网站。

专栏介绍

专栏名称

专栏介绍

《C语言》

本专栏主要撰写C干货内容和编程技巧,让大家从底层了解C,把更多的知识由抽象到简单通俗易懂。

《网络协议》

本专栏主要是注重从底层来给大家一步步剖析网络协议的奥秘,一起解密网络协议在运行中协议的基本运行机制!

《docker容器精解篇》

全面深入解析 docker 容器,从基础到进阶,涵盖原理、操作、实践案例,助您精通 docker。

《linux系列》

本专栏主要撰写Linux干货内容,从基础到进阶,知识由抽象到简单通俗易懂,帮你从新手小白到扫地僧。

《python 系列》

本专栏着重撰写Python相关的干货内容与编程技巧,助力大家从底层去认识Python,将更多复杂的知识由抽象转化为简单易懂的内容。

《试题库》

本专栏主要是发布一些考试和练习题库(涵盖软考、HCIE、HRCE、CCNA等)

目录

⛳️ 推荐

专栏介绍

🔧 安装与检查OpenSSH

👤 创建专用的SFTP用户和组

📁 建立安全的目录结构

⚙️ 配置SSH服务器(关键步骤)

🚀 重启服务与测试连接

⚠️ 常见问题排查


img

在CentOS 7上搭建一个安全的SFTP服务器,核心是配置一个“监牢”环境,将用户限制在指定目录内。下面这张流程图帮你快速了解整个操作的全貌。

flowchart TD
A[开始搭建SFTP服务器] –> B[安装与启动OpenSSH]
B –> C[创建专用用户和组]
C –> D[建立严格的目录结构]
D –> E[配置SSH以启用chroot]
E –> F[重启服务并测试]
F –> G[SFTP服务就绪]

C –> C1[创建用户组sftpusers]
C –> C2[创建用户并禁止shell登录]
D –> D1[设置根目录属主为root]
D –> D2[创建用户可写的子目录]
E –> E1[启用internal-sftp]
E –> E2[匹配用户组并设置chroot]
F –> F1[重启sshd服务]
F –> F2[使用客户端连接测试]

以下是每个步骤的详细操作说明。

🔧 安装与检查OpenSSH

SFTP是OpenSSH的一个子系统,因此首先需要确保OpenSSH服务器已安装并运行。

  • 安装OpenSSH服务器(通常系统已预装):

    sudo yum install -y openssh-server

  • 启动并设置开机自启:

    sudo systemctl start sshd
    sudo systemctl enable sshd

  • 检查防火墙:如果防火墙(firewalld)是开启状态,需要放行SSH默认的22端口。

    sudo firewall-cmd –permanent –add-service=ssh
    sudo firewall-cmd –reload

    如果使用的是云服务器(如阿里云、腾讯云),还需在云平台的安全组规则中放行TCP 22端口。

  • 👤 创建专用的SFTP用户和组

    为了管理方便和安全,我们为SFTP用户创建一个独立的组和用户。

  • 创建用户组(例如 sftpusers):

    sudo groupadd sftpusers

  • 创建SFTP用户(例如用户名为 mysftpuser),并禁止其通过SSH获得Shell终端,这是关键的安全措施:

    sudo useradd -g sftpusers -s /sbin/nologin mysftpuser

  • 为用户设置密码:

    sudo passwd mysftpuser

  • 📁 建立安全的目录结构

    这是实现“监牢”环境的物理基础,目录权限设置至关重要。

  • 创建SFTP根目录:选择一个目录作为所有SFTP用户的根目录,例如 /sftp。

    sudo mkdir /sftp

  • 设置根目录权限:该目录的拥有者必须是 root,且其他用户不能有写权限,否则SSH会出于安全考虑拒绝连接。

    sudo chown root:root /sftp
    sudo chmod 755 /sftp # 权限必须是755或更严格(如750)

  • 创建用户专属目录:在根目录下为刚创建的用户建立一个目录,此目录将是该用户登录后看到的唯一位置。

    sudo mkdir /sftp/mysftpuser

  • 设置用户子目录权限:用户专属目录的权限同样需要严格设置。

    sudo chown root:root /sftp/mysftpuser # 属主仍为root
    sudo chmod 755 /sftp/mysftpuser

  • 创建用户可操作的子目录:用户需要一个有写权限的目录来上传文件,例如 upload。

    sudo mkdir /sftp/mysftpuser/upload
    sudo chown mysftpuser:sftpusers /sftp/mysftpuser/upload # 此目录属主为用户
    sudo chmod 755 /sftp/mysftpuser/upload # 可根据需要设置为766或770

  • ⚙️ 配置SSH服务器(关键步骤)

    通过修改SSH配置文件,将用户锁定在指定的根目录内。

  • 编辑配置文件:

    sudo vi /etc/ssh/sshd_config

  • 在文件末尾添加以下配置:这些配置指示SSH为 sftpusers组的用户启用内部SFTP服务,并将其限制在指定的根目录。

    # 注释掉或确保以下行存在,使用内置SFTP实现
    Subsystem sftp internal-sftp

    # 匹配sftpusers组,应用以下规则
    Match Group sftpusers
    # 设置chroot根目录,%u代表用户名,这里用户将锁定在/sftp/mysftpuser
    ChrootDirectory /sftp/%u
    # 强制使用SFTP,禁止Shell访问
    ForceCommand internal-sftp
    # 禁用不相关的功能以增强安全
    AllowTcpForwarding no
    X11Forwarding no

  • 在保存修改前,务必检查配置语法,防止配置错误导致SSH服务无法启动:

    sudo sshd -t

    如果该命令没有输出任何错误信息,说明配置文件语法正确。

  • 🚀 重启服务与测试连接

  • 重启SSH服务以应用所有更改:

    sudo systemctl restart sshd

  • 使用SFTP客户端连接测试:

    • 使用如FileZilla、WinSCP等客户端。

    • 服务器地址填你的CentOS 7的IP,端口22。

    • 用户名填 mysftpuser,密码是你设置的密码。

    • 连接成功后,你应该只能看到 upload目录,并且无法切换到其上级目录。

  • ⚠️ 常见问题排查

    • 连接被立即关闭:最常见的原因是Chroot目录(如 /sftp/mysftpuser)的权限设置错误。请确保其属主是 root,并且权限不超过755。

    • 无法上传文件/创建目录:用户只能在属于自己且有写权限的子目录(如 upload)中进行写操作。请检查该子目录的属主和权限。

    • SELinux阻止:如果启用了SELinux,可能需要调整策略:

      sudo setsebool -P ssh_chroot_rw_homedirs on

    按照以上步骤操作,你就能在CentOS 7上成功搭建一个安全的SFTP服务器了。如果你在配置过程中遇到具体问题,例如错误信息,可以告诉我,我们再一起分析。

    ❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄

    💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍

    🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

    赞(0)
    未经允许不得转载:网硕互联帮助中心 » HoRain云--CentOS7搭建安全SFTP服务器全攻略
    分享到: 更多 (0)

    评论 抢沙发

    评论前必须登录!