先立后破:Linux 下“新建管理员 → 验证 → 禁用 root 远程 SSH”的零翻车笔记

先立后破:Linux 下"新建管理员 → 验证 → 禁用 root 远程 SSH"的零翻车笔记

前言

等保 2.0 明确要求"默认账户 root 应限制远程访问",但直接 PermitRootLogin no 容易把自己锁在门外。

本文给出一条可回滚、零翻车 的标准流程:先建"替身"管理员 → 验证其 sudo 可用 → 再关闭 root 远程,全程保持 root 会话不断, 100 % 远程可维护。


环境

  • OS:Kylin V10 / CentOS 7/8 / RHEL 7/8 均通用
  • 权限:已有 root 远程会话(Terminal-A,以下简称 T-A)
  • 工具:openssh + systemd

步骤 1:新建替身账号(T-A 里执行)

bash 复制代码
# 1. 建用户、home 目录、描述
useradd -m -c "SysAdmin" admin

# 2. 设复杂口令(8+,含大小写、数字、特殊符)
passwd admin

步骤 2:给替身加 sudo 权限

Kylin/centos 已预置 wheel 组,只需加进去即可:

bash 复制代码
usermod -aG wheel admin

若系统没 wheel,可 visudo 追加 admin ALL=(ALL) NOPASSWD:ALL 或需要密码的 ALL=(ALL) ALL


步骤 3:必须验证 sudo 可用(开新终端测)

  1. 本地另开 Terminal-B,连接测试:

    bash 复制代码
    ssh admin@服务器IP
  2. 提权测试:

    bash 复制代码
    sudo -i
    # 若看到 root@hostname 提示符 → 成功
  3. 如果提示不在 sudoers,回到 T-A 执行 visudo 检查 %wheel 行是否被注释,取消注释后再次测试,直到 sudo -i 畅通无阻。


步骤 4:修改 sshd 配置(仍在 T-A)

bash 复制代码
vim /etc/ssh/sshd_config
# 找到并修改
PermitRootLogin no
# (可选)仅允许指定账户,防止其他人
AllowUsers admin

保存后先做语法检查:

bash 复制代码
sshd -t

无报错再重载服务(绝不 restart,用 reload 不断连接):

bash 复制代码
systemctl reload sshd

步骤 5:验证 root 远程已失效

在 Terminal-C 故意登录 root:

bash 复制代码
ssh root@服务器IP

预期结果:
Permission denied, please try again. 或无法输入密码 → 成功!


步骤 6:保留 root 本地通道(可选但强烈建议)

PermitRootLogin no 仅影响 ssh,本机控制台(iDRAC/IPMI/物理显示器)仍可用 root 应急登录,防止极端情况。


步骤 7:后续加固(admin 会话里执行)

  1. 改端口 + 密钥登录 + fail2ban,一条龙:

    bash 复制代码
    vim /etc/ssh/sshd_config
    Port 2222
    PasswordAuthentication no
    PubkeyAuthentication yes

    reload 后把公钥 ssh-copy-id -p 2222 admin@IP

  2. 日志审计:

    bash 复制代码
    systemctl enable --now auditd

    按等保要求加规则(见历史推文)。

  3. 把操作过程截图写进《安全加固报告》即可交差。


一键回滚(万一翻车了)

T-A 仍在线,立即:

bash 复制代码
vim /etc/ssh/sshd_config
PermitRootLogin yes
systemctl reload sshd

root 远程瞬间恢复,排查完再关。


结语

"先立后破"是生产网铁律:
新账号没 sudo → 绝不关 root;
验证窗口没通过 → 绝不 reload sshd。

按上面 7 步走,既能满足等保,也能保住饭碗。祝你加固顺利,远离"人在途中,root 被拒"的尴尬!

相关推荐
chlk1231 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑1 天前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件1 天前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
深紫色的三北六号1 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash2 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI2 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行3 天前
Linux和window共享文件夹
linux
木心月转码ing3 天前
WSL+Cpp开发环境配置
linux
埃博拉酱4 天前
VS Code Remote SSH 连接 Windows 服务器卡在"下载 VS Code 服务器":prcdn DNS 解析失败的诊断与 BITS 断点续传
windows·ssh·visual studio code
崔小汤呀4 天前
最全的docker安装笔记,包含CentOS和Ubuntu
linux·后端