0

0

LinuxSSH安全怎么提升_操作步骤详解提升实战能力【教程】

舞夢輝影

舞夢輝影

发布时间:2025-12-14 17:00:08

|

767人浏览过

|

来源于php中文网

原创

Linux SSH安全提升需按顺序执行五步:禁用root和空密码登录;强制密钥认证并禁用密码登录;修改默认端口并配置防火墙白名单;限制允许登录的用户及来源IP;启用连接超时与Fail2Ban失败锁定机制。

linuxssh安全怎么提升_操作步骤详解提升实战能力【教程】

直接上干货:Linux SSH 安全提升不是堆功能,而是层层设防。核心是“关掉默认漏洞、用更牢的认证、限制谁和怎么连”。下面按实战顺序讲清楚最关键的五步,每步都带配置要点和注意事项。

禁用 root 登录和空密码

这是最基础也最容易被忽略的一环。root 直连等于把大门钥匙挂门上;空密码用户则相当于门没锁。

  • 编辑 /etc/ssh/sshd_config,确认以下两行已设置并取消注释:

PermitRootLogin no
PermitEmptyPasswords no

  • 改完必须重启服务:sudo systemctl restart sshd(CentOS/RHEL 用 sshd,Ubuntu/Debian 用 ssh
  • 验证方式:用 root 尝试 ssh 登录,应直接拒绝;清空某用户密码后尝试登录,也应失败

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

密码再强也扛不住暴力扫描,而密钥认证(尤其是 4096 位 RSA 或 Ed25519)几乎无法爆破。

  • 本地生成密钥:ssh-keygen -t ed25519 -a 100(推荐,比 RSA 更快更安全)
  • 上传公钥到服务器:ssh-copy-id -i ~/.ssh/id_ed25519.pub user@server_ip -p 2222(若已改端口需加 -p
  • 修改 /etc/ssh/sshd_config

PubkeyAuthentication yes
PasswordAuthentication no
PermitEmptyPasswords no(再次确认)

  • ⚠️ 操作前务必确保密钥已生效且你有其他方式(如控制台)可回滚,否则可能锁死自己

修改默认端口 + 配合防火墙白名单

端口 22 是扫描器的“打卡点”,换一个非常规端口(比如 2025、5922、22222)能过滤掉 80%+ 的自动化攻击。

OpenArt
OpenArt

在线AI绘画艺术图片生成器工具

下载
  • /etc/ssh/sshd_config 中设置:Port 2025(选 1024–65535 之间未被占用的端口)
  • 更新防火墙规则:

—— Ubuntu/Debian(ufw):sudo ufw allow 2025/tcp && sudo ufw enable
—— CentOS/RHEL(firewalld):sudo firewall-cmd --permanent --add-port=2025/tcp && sudo firewall-cmd --reload

  • SELinux 用户注意:改端口后需运行 sudo semanage port -a -t ssh_port_t -p tcp 2025,否则启动会失败
  • 测试新端口连接:ssh -p 2025 user@server_ip

限制可登录用户和来源 IP

最小权限原则:只让必要的人、从必要的地方进来。

  • /etc/ssh/sshd_config 中添加(一行写完):

AllowUsers deploy@192.168.1.0/24 admin@203.12.45.112

  • 支持用户名+IP 组合,多个用户用空格分隔;不匹配的任何尝试都会被直接拒绝
  • 如果用的是云服务器,建议只允许可信办公 IP 或跳板机 IP,避免开放整个公网段
  • 改完记得重载:sudo systemctl reload sshd(reload 比 restart 更轻量,不中断已有连接)

启用连接超时与失败锁定机制

防止空闲会话被劫持,也压制暴力试探。

  • /etc/ssh/sshd_config 中加入:

ClientAliveInterval 300(每 5 分钟发一次心跳)
ClientAliveCountMax 3(连续 3 次无响应就断开,即 15 分钟无操作自动登出)
MaxAuthTries 4(单次连接最多试 4 次密码,防爆破)

  • 搭配 Fail2Ban 效果更佳:安装后默认监控 /var/log/auth.log,触发 5 次失败即封 IP 10 分钟
  • 安装命令(Ubuntu):sudo apt install fail2ban && sudo systemctl enable --now fail2ban
  • 查看封禁状态:sudo fail2ban-client status sshd

基本上就这些。不需要一步到位,但建议按顺序做:先禁 root 和空密码 → 再切密钥 → 然后改端口+防火墙 → 接着限用户/IP → 最后加超时和 Fail2Ban。每步验证后再推进,稳扎稳打。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

390

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

572

2023.08.10

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

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

1349

2023.06.21

如何安装LINUX
如何安装LINUX

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

702

2023.06.29

linux find
linux find

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

294

2023.06.30

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

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

776

2023.07.05

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

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

572

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

545

2023.07.20

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

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

精品课程

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

共48课时 | 7.3万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

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

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