当前位置: 首页
编程语言
SFTP配置时如何防止暴力破解

SFTP配置时如何防止暴力破解

热心网友 时间:2026-04-24
转载

SFTP防暴力破解的实用配置清单

SFTP配置时如何防止暴力破解

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

一 基础加固

这部分的配置,可以说是整个防御体系的基石。做好了,能直接挡掉绝大部分自动化脚本的骚扰。

  • 禁用密码登录、仅用密钥:这是最关键的一步。操作路径在 /etc/ssh/sshd_config 里,把 PasswordAuthentication 设为 no,同时确保 PubkeyAuthenticationyes。客户端那边,用 ssh-keygen -t rsa -b 4096 这类命令生成密钥对,然后把公钥内容塞进服务器的 ~/.ssh/authorized_keys 文件。别忘了,权限设置是门学问,.ssh 目录权限得是 700,authorized_keys 文件得是 600,这一步错了,前面可能都白搭。
  • 禁止 root 直登:没什么好商量的,PermitRootLogin 直接改成 no。先让攻击者猜不到用户名,这门槛就高了不少。
  • 可选降低噪声:把默认的 22 端口改成比如 2222。这招的效果嘛,好比把自家门牌号从热闹的大街挪到小巷里,并不能让门锁变得更结实,但能显著减少被“路过”的自动化扫描工具碰上的概率。记住,这只是辅助,不能替代认证加固。
  • 重启生效:改完配置,systemctl restart sshd 一下。上面这几板斧下去,尤其是“禁用密码+仅密钥”这个组合拳,对于SFTP这种特定场景,被暴力猜解的风险已经能降到一个很低的水平了。

二 自动封禁与速率限制

基础加固是修高墙,那这部分就是部署巡逻队和设置关卡流量控制,形成纵深防御。

  • 使用 Fail2Ban 监控 SSH 登录失败并封 IP
    • 安装yum install fail2ban -y 或者 apt-get install fail2ban,看你的系统口味。
    • 配置(示例):核心是创建 /etc/fail2ban/jail.local 文件。里面大致这么写:
      [DEFAULT]
      bantime = 600
      findtime = 600
      maxretry = 3
      [sshd]
      enabled = true
      port = ssh
      filter = sshd
      logpath = /var/log/secure # CentOS/RHEL 用这个
      # logpath = /var/log/auth.log # Debian/Ubuntu 用这个
      maxretry = 3
      bantime = 600
      意思很直白:10分钟(600秒)内,同一个IP失败3次,就关它10分钟“禁闭”。
    • 启动systemctl start fail2ban && systemctl enable fail2ban。想看看“巡逻队”工作状态?fail2ban-client status sshd 命令给你答案。
  • 用防火墙做连接速率限制(iptables 示例)
    • 规则:这两条 iptables 规则值得记一下:
      iptables -A INPUT -p tcp --dport 22 -m state --state NEW -m recent --set
      iptables -A INPUT -p tcp --dport 22 -m state --state NEW -m recent --update --seconds 60 --hitcount 4 -j DROP
      它们实现的效果是:60秒内,如果同一个IP对22端口的新连接请求超过4个,后续的请求就直接丢弃。用 firewalld 的话,也可以通过 direct 规则达到相同目的。

看出来了吗?Fail2Ban 是“事后追责”,发现异常再封禁;而防火墙速率限制是“事前预防”,直接从流量上掐断高频试探。两者一结合,防御的层次感和反应速度就都有了。

三 登录失败锁定与账户策略

如果说前面是防外人,那这里就是管好自家“钥匙”,并且给每把钥匙加上试错自锁功能。

  • PAM 失败计数与解锁
    • 使用 pam_tally2(RHEL/CentOS 常用):在 /etc/pam.d/sshd 文件顶部加入:
      auth required pam_tally2.so onerr=fail deny=3 unlock_time=600
      意思是:失败3次就锁定账户,600秒后自动解锁。如果需要手动给某个用户解锁,执行 faillog -u <用户名> -r 就行。
    • 使用 pam_faillock(更现代,部分新发行版默认):同样在 /etc/pam.d/sshd 顶部加入:
      auth required pam_faillock.so preauth silent deny=3 unlock_time=600
      然后在文件底部加上:
      account required pam_faillock.so
  • 强密码策略:即使我们主要用密钥,但系统其他账户或备用方案仍需强密码。在 /etc/pam.d/system-auth/etc/pam.d/password-auth 中,通过 pam_pwquality 或 pam_cracklib 模块配置,强制要求密码长度、包含字符种类,并避免使用历史密码。

PAM模块的锁定是应用层面的即时反应,速度非常快。它和网络层的Fail2Ban配合,一个管“用户账户”,一个管“来源IP”,能覆盖从短时爆破到长时间慢速试探的各种攻击窗口。

四 系统与服务最小化

安全领域有句老话:最安全的服务是根本不运行的服务。所以,我们要收窄攻击面。

  • 仅启用 SFTP 子系统:在 /etc/ssh/sshd_config 中,确保类似这样的配置是启用的:
    Subsystem sftp /usr/libexec/openssh/sftp-server
    (注意,具体路径可能因发行版而异)。这样,SSH服务就只提供SFTP功能,关掉其他不必要的子系统。
  • 保持系统与 OpenSSH 更新:这点听起来像是老生常谈,但至关重要。及时打上安全补丁,才能堵住那些已知的漏洞。最小化攻击面是“静态加固”,及时更新则是“动态维护”,两者结合才是长治久安的基础。

五 快速验证与运维建议

配置完了,怎么知道它真的在起作用?日常运维又该注意什么?

  • 验证与观测
    • 查看 Fail2Ban 状态:fail2ban-client status sshd。想实时看谁被关了“禁闭”?tail -f /var/log/fail2ban.log 是个好选择。
    • 本地验证登录失败计数:用 faillog -u <用户名> 命令(如果用的是pam_tally2)。
  • 运维要点
    • 变更前先备份:动 /etc/ssh/sshd_config/etc/fail2ban/jail.local 这些关键文件前,先复制一份。改完后,逐步重启服务并检查现有会话是否正常。
    • 善用云平台能力:如果服务器在云上,别忘了云厂商提供的安全组或防火墙规则。可以在那里叠加一层来源IP白名单和速率限制策略,与主机层面的防护形成互补的多层防护。

说到底,安全不是一劳永逸的配置,而是一个持续的过程。通过上面这些状态检查和日志审计手段,你才能快速确认策略是否生效,并在第一时间发现那些不请自来的“客人”。

来源:https://www.yisu.com/ask/81654549.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
ubuntu里nodejs如何备份

ubuntu里nodejs如何备份

在Ubuntu系统中备份Node js应用程序 给运行在Ubuntu上的Node js应用做备份,这事儿说简单也简单,但步骤没做对,关键时刻可能就抓瞎。一个完整的备份方案,通常得覆盖代码、数据、配置和日志这几个核心部分。下面这套流程,算是经过不少实战检验的“标准动作”,照着做,基本能确保万无一失。

时间:2026-04-24 22:35
ubuntu中nodejs依赖怎么装

ubuntu中nodejs依赖怎么装

在 Ubuntu 系统中安装 Node js 依赖 想在 Ubuntu 上搞定 Node js 环境?其实路径不止一条。下面这几种主流方法,各有各的适用场景,你可以根据自己对版本管理、系统集成度的需求来灵活选择。 1 使用包管理器(推荐) 对于大多数 Ubuntu 用户来说,最直接、最省心的方式,

时间:2026-04-24 22:34
ubuntu里nodejs怎么配置

ubuntu里nodejs怎么配置

Ubuntu 下 Node js 配置全流程 一 安装方式选择 在Ubuntu上配置Node js,第一步也是关键一步,就是选对安装方法。不同的方法对应着不同的使用场景,选对了,后续工作事半功倍。 使用 APT 官方仓库:命令最简单,适合追求快速上手的场景。不过,官方仓库的版本更新往往不那么及时,可

时间:2026-04-24 22:34
ubuntu中nodejs报错怎么办

ubuntu中nodejs报错怎么办

在Ubuntu系统中,如果Node js报错,可以尝试以下方法来解决问题 遇到Node js报错先别慌,很多时候问题出在一些基础环节。按照下面这几个步骤排查一遍,大部分问题都能迎刃而解。 1 确认Node js是否已正确安装 第一步,也是最基础的一步:检查Node js和它的包管理器npm是否真的

时间:2026-04-24 22:34
ubuntu下nodejs如何卸载

ubuntu下nodejs如何卸载

Ubuntu 下卸载 Node js 的实用步骤 在 Ubuntu 上彻底清理 Node js,第一步不是急着敲命令,而是得先搞清楚它当初是怎么来的。不同的安装方式,决定了完全不同的卸载路径。盲目操作,很可能留下各种“历史遗留问题”。 一、先确认安装来源 动手之前,花一分钟做个快速诊断,能让你事半功

时间:2026-04-24 22:34
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程