0

0

Linux SSH 安全强化与访问控制

冷炫風刃

冷炫風刃

发布时间:2026-02-20 11:21:34

|

340人浏览过

|

来源于php中文网

原创

ssh安全加固需四步:改非标端口(如2222)并关闭22端口;禁用密码认证,强制密钥登录;配置allowusers白名单限制登录用户;设置clientaliveinterval 300与clientalivecountmax 2清理僵死连接。

linux ssh 安全强化与访问控制

SSH 服务默认端口暴露在公网就是风险源

22 端口被暴力扫描是常态,不是“可能”,而是“一定”——只要你的服务器有公网 IP 且 sshd 监听 0.0.0.0:22,每天都会收几百到几千次密码爆破。这不是小概率事件,是基础设施层面的默认攻击面。

改端口不能防高级攻击,但能过滤掉 95% 以上的自动化脚本。别信“改了端口就不安全”的说法,它不解决根本问题,但确实大幅降低噪音和误报干扰。

  • Port 改成非标准值(比如 222222022),必须在 /etc/ssh/sshd_config 中显式设置,不能只靠防火墙 redirect
  • 改完后运行 sudo systemctl restart sshd,再用 sudo ss -tlnp | grep :2222 确认监听生效
  • 防火墙(如 ufw)要同步放行新端口,同时 立刻关闭旧端口 22 的入向规则,否则等于没改
  • 客户端连接时必须显式指定端口:ssh -p 2222 user@host,别漏 -p

密码登录开着等于给机器人发钥匙

哪怕你密码很复杂,只要允许密码认证,sshd 就得接收并校验每一次尝试——这本身就在消耗资源、留下日志噪音,还可能被撞库或重放利用。密钥登录才是 Linux SSH 的事实标准。

禁用密码不是为了“更酷”,是为了让登录行为可追溯、不可批量、失败成本高。

  • 确认 /etc/ssh/sshd_configPasswordAuthentication noPubkeyAuthentication yes 都已启用
  • 改配置前,先用新密钥登录成功一次——别在唯一会话里改完就重启,否则可能锁死
  • 私钥务必设 umask 077,文件权限必须是 600,否则 ssh 客户端会直接拒绝加载
  • 如果用了 ssh-agent,记得 ssh-add ~/.ssh/id_rsa 后再测试,否则本地也连不上

AllowUsers 比防火墙规则更早拦住非法用户

防火墙只能按 IP 或端口过滤,而 AllowUsers 是 SSH 协议层的第一道身份闸门——它在认证前就拒绝非名单用户的连接请求,不分配 session、不记录 auth 日志、不触发 PAM。

迅易年度企业管理系统开源完整版
迅易年度企业管理系统开源完整版

系统功能强大、操作便捷并具有高度延续开发的内容与知识管理系统,并可集合系统强大的新闻、产品、下载、人才、留言、搜索引擎优化、等功能模块,为企业部门提供一个简单、易用、开放、可扩展的企业信息门户平台或电子商务运行平台。开发人员为脆弱页面专门设计了防刷新系统,自动阻止恶意访问和攻击;安全检查应用于每一处代码中,每个提交到系统查询语句中的变量都经过过滤,可自动屏蔽恶意攻击代码,从而全面防止SQL注入攻击

下载

它比 DenyUsers 更安全,因为白名单天然防漏,黑名单永远追着新账号跑。

  • /etc/ssh/sshd_config 中写死允许登录的用户,例如:AllowUsers deploy@192.168.1.* admin@2001:db8::/64
  • 支持用户名 + 可选 IP 段组合,IP 部分留空表示任意来源(不推荐),建议绑定可信出口 IP 或 IPv6 前缀
  • 多个用户用空格分隔,不要换行,否则第二行会被忽略
  • 修改后必须 sudo sshd -t 测试配置语法,再 sudo systemctl reload sshd(reload 比 restart 更稳妥)

ClientAliveInterval 不是保活,是主动断开僵死连接

很多人以为这个参数是为了防止终端断开,其实它的核心作用是清理那些没真正退出、却不再响应的 SSH 连接——比如网络中断后客户端没发 FIN,或者用户关了笔记本但没登出,这些连接会一直占着 sshd 子进程和内存。

不设的话,几十个僵尸连接就能拖慢新连接建立,甚至触发系统级连接数限制。

  • 推荐配对使用:ClientAliveInterval 300(每 5 分钟发一次探针) + ClientAliveCountMax 2(连续两次无响应就断开)
  • 注意:这个机制只对已认证成功的连接生效,不影响登录过程中的握手阶段
  • 如果用了跳板机或中间代理,确保探针包能双向穿透,否则可能误杀正常连接
  • 配合 netstat -tnp | grep :22 观察 ESTABLISHED 连接数变化,验证是否真正在回收

最常被跳过的其实是配置重载后的连通性验证——改完 sshd_config,光看 systemctl status sshd 没用,得从另一台机器上真实走一遍登录流程,包括密钥、端口、用户白名单三者同时满足。少一个环节,就等于开了个暗门。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

328

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

773

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

97

2025.08.19

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

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

1520

2023.06.21

如何安装LINUX
如何安装LINUX

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

714

2023.06.29

linux find
linux find

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

300

2023.06.30

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

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

791

2023.07.05

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

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

584

2023.07.06

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

776

2026.02.13

热门下载

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

精品课程

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

共48课时 | 9.4万人学习

Git 教程
Git 教程

共21课时 | 3.7万人学习

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

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