0

0

Linux 如何防止 SSH 暴力破解

舞夢輝影

舞夢輝影

发布时间:2026-01-29 19:16:56

|

512人浏览过

|

来源于php中文网

原创

fail2ban是最直接有效的防御手段,它监控auth.log或secure日志,识别连续失败的SSH登录并调用iptables/nftables封禁IP;需启用sshd过滤器、设maxretry为3~5、bantime≥3600秒,适配nftables后启动服务并验证状态。

linux 如何防止 ssh 暴力破解

用 fail2ban 自动封禁反复失败的 IP

fail2ban 是最直接有效的防御手段,它监控 /var/log/auth.log(或 /var/log/secure,取决于发行版),识别连续失败的 SSH 登录尝试,并自动调用 iptablesnftables 封禁源 IP。

安装后默认已包含 sshd 过滤器,但需确认启用:

  • 检查 /etc/fail2ban/jail.local[sshd] 段是否设置 enabled = true
  • maxretry 建议设为 3~5,bantime 至少 3600(1 小时),避免误封后立即解封
  • 若系统用 nftables,需在 [sshd] 下指定 backend = systemd 或确保 banaction 匹配(如 banaction = nftables
  • 启动服务:systemctl enable --now fail2ban,之后用 fail2ban-client status sshd 验证运行状态

禁用密码登录,强制使用密钥认证

只要关闭密码登录,暴力破解就失去意义——攻击者无法靠穷举口令进入系统。

操作前务必确保已有可用的 SSH 密钥对且公钥已写入 ~/.ssh/authorized_keys,否则会锁死自己:

  • 编辑 /etc/ssh/sshd_config,将 PasswordAuthentication 设为 no
  • 同时确认 PubkeyAuthentication yesAuthorizedKeysFile .ssh/authorized_keys 未被注释或改写
  • 重启服务:systemctl restart sshd;建议开第二个终端测试新连接再关闭原会话
  • 注意:某些云平台控制台(如 AWS EC2 Serial Console)可能依赖密码或特殊凭证,禁用前需确认备用访问通道

修改默认 SSH 端口并限制监听范围

把 SSH 从 22 换到非标端口(如 2222)不能替代其他防护,但能过滤掉大量自动化扫描流量;配合 ListenAddress 可进一步缩小暴露面。

考拉新媒体导航
考拉新媒体导航

考拉新媒体导航——新媒体人的专属门户网站

下载

这不是“隐藏即安全”,而是降低日志噪音和初始攻击密度:

  • /etc/ssh/sshd_config 中取消注释并修改 Port 行,例如 Port 2222
  • 添加 ListenAddress 指定仅监听内网或特定 IP:ListenAddress 192.168.1.100ListenAddress ::1(仅本地 IPv6)
  • 防火墙必须同步放行新端口:ufw allow 2222nft add rule ip filter input tcp dport 2222 accept
  • SELinux 用户还需运行 semanage port -a -t ssh_port_t -p tcp 2222,否则 sshd 启动失败

用 sshd 的 AllowUsers / AllowGroups 严格限定可登录账户

即使密钥或密码泄露,攻击者也必须猜中用户名才能发起认证请求。限制允许登录的用户列表,等于给入口加了一道白名单门禁。

这比单纯禁用 root 登录更进一步,尤其适合多用户环境:

  • /etc/ssh/sshd_config 中添加 AllowUsers alice bob@192.168.1.*(支持用户名+IP 模式)
  • 或使用 AllowGroups sshusers,然后把合法用户加入该组:usermod -aG sshusers alice
  • 注意:配置后所有未显式列出的用户(包括 root)均无法登录,哪怕密钥正确也不行
  • 若用 AllowGroups,确保组名拼写与 /etc/group 一致,大小写敏感

真正起效的防护是组合动作:fail2ban 应对试探、密钥登录消除口令爆破面、端口与地址限制减少无效连接、白名单收窄合法身份范围。最容易被忽略的是变更配置后的连通性验证——别等锁住自己才想起没留后门。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
console接口是干嘛的
console接口是干嘛的

console接口是一种用于在计算机命令行或浏览器开发工具中输出信息的工具,提供了一种简单的方式来记录和查看应用程序的输出结果和调试信息。本专题为大家提供console接口相关的各种文章、以及下载和课程。

415

2023.08.08

console.log是什么
console.log是什么

console.log 是 javascript 函数,用于在浏览器控制台中输出信息,便于调试和故障排除。想了解更多console.log的相关内容,可以阅读本专题下面的文章。

510

2024.05.29

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

186

2023.11.24

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1415

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

706

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

295

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

782

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

575

2023.07.06

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8万人学习

Git 教程
Git 教程

共21课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号