Linux 找回 Root 密码(多发行版本)

适用于大多数 Linux 发行版(Ubuntu、CentOS、Debian 等),无需第三方工具,需物理接触服务器或系统启动权限


步骤 1:重启系统并进入 GRUB 引导菜单
  1. 重启系统,看到启动画面时,快速按下 EscShiftE(不同系统按键不同,可多试几次)。
  2. 进入 GRUB 菜单 后,选择要修改的系统内核选项(通常第一个),按 e 进入编辑模式。

步骤 2:修改内核启动参数
  1. 找到以 linuxlinux16linuxefi 开头的行(可能显示为 ro quiet splash),ro 改为 rw init=/bin/bash (部分系统需改为 rw single)。

    复制代码

    <BASH>

    复制代码
    linux /vmlinuz-xxx root=/dev/sda1 **rw init=/bin/bash**
    • 目的 :以可读写(rw)模式启动,并直接进入单用户模式(无需密码)。

步骤 3:挂载文件系统并修改密码
  1. 按下 Ctrl+XF10 启动到命令行界面。

  2. 重新挂载根分区为读写模式 (部分系统已通过参数自动挂载):

    复制代码

    <BASH>

    复制代码
    mount -o remount,rw /
  3. 修改 Root 密码

    复制代码

    <BASH>

    复制代码
    passwd root    # 输入两次新密码
  4. 确保 SELinux 重新标记 (如系统使用 SELinux):

    复制代码

    <BASH>

    复制代码
    touch /.autorelabel  # CentOS/RHEL 需要此步骤
  5. 重启系统:

    复制代码

    <BASH>

    复制代码
    exec /sbin/init      # 或直接按 Ctrl+Alt+Delete

其他可能场景处理
场景 1:系统使用 systemd(如 Ubuntu 18.04+、CentOS 7+)
  1. 在 GRUB 编辑模式中,修改 linux 行末尾为:

    复制代码

    <BASH>

    复制代码
    rw init=/bin/bash
  2. 若提示文件系统错误,需指定根分区:

    复制代码

    <BASH>

    复制代码
    mount -o remount,rw /sysroot
    chroot /sysroot
    passwd root
    touch /.autorelabel  # 仅 SELinux 系统需要
    exit
    reboot
场景 2:使用 Live CD/USB 修改密码
  1. 用 Linux Live USB 启动系统。

  2. 挂载原系统的根分区(需替换 /dev/sda1 为实际分区):

    复制代码

    <BASH>

    复制代码
    sudo mount /dev/sda1 /mnt
  3. 修改密码:

    复制代码

    <BASH>

    复制代码
    sudo chroot /mnt
    passwd root
    exit
    sudo reboot

注意事项
  1. 安全限制
    • 要求物理访问机器,虚拟机需控制台权限。
    • 若启用了全盘加密(如 LUKS),需先解密磁盘。
    • Secure Boot 可能阻止此操作,需在 BIOS/UEFI 中临时关闭。
  2. 生产环境
    • 修改密码后检查系统日志(/var/log/secure/var/log/auth.log)。
    • 启用 SSH 密钥认证或 sudo 权限,减少依赖 Root 密码。

示例流程图

复制代码

<PLAINTEXT>

复制代码
重启 → GRUB菜单 → 修改启动参数 → 进入单用户模式 → 挂载rw → passwd → 重启生效

通过上述步骤,可快速恢复 Root 权限,建议操作后加固系统安全! 🔐

相关推荐
黄筱筱筱筱筱筱筱23 分钟前
LINUX-防火墙
linux·服务器·网络
сокол1 小时前
【网安-Web渗透测试-靶场系列】AWD-Platform(ctf-hub)
linux·服务器·ubuntu·网络安全·docker
utf8mb4安全女神2 小时前
Linux系统服务相关命令【定时任务设置】【任务进程管理】【防火墙区域应用】
linux·运维·服务器
凯丨2 小时前
Claude Code 自动化开发的完整体系
运维·自动化
SilentSamsara5 小时前
concurrent.futures 实战:进程池与线程池的统一抽象
运维·开发语言·python·青少年编程
不吃土豆的马铃薯5 小时前
Spdlog 进阶:日志基本控制、日志格式控制、异步记录器
linux·服务器·开发语言·前端·c++
疯狂成瘾者5 小时前
常见的 Linux 版本
linux·运维·服务器
szxinmai主板定制专家5 小时前
基于ZYNQ MPSOC图像采集与压缩系统总体设计方案
linux·arm开发·人工智能·嵌入式硬件·fpga开发
liulilittle5 小时前
TCP UCP:基于卡尔曼滤波的BBR增强型拥塞控制算法
linux·网络·c++·tcp/ip·算法·c·通讯
xingyuzhisuan5 小时前
GPU服务器集群搭建指南——选型、部署、优化+避坑全解析
运维·服务器·人工智能·gpu算力