linux中如何删除账户密码忘记

Linux系统中,无论是管理员忘记root密码导致无法管理系统,还是普通用户忘记登录密码无法进入系统,都会严重影响日常使用,此时需通过底层方法重置密码,而非常规的passwd命令(因无法登录),本文将分场景详细介绍密码重置方案,涵盖GRUB引导、救援模式等常见方法,并附操作注意事项及FAQs。

linux中如何删除账户密码忘记

root密码丢失:通过GRUB单用户模式重置

root账户是Linux系统的超级管理员,密码丢失后需通过引导加载程序(如GRUB)进入单用户模式或紧急模式,绕过密码验证直接修改系统文件。

操作步骤(以Ubuntu/Debian为例)

  1. 重启系统并进入GRUB菜单
    开机时迅速按下Esc键(或Shift键,不同主板可能不同),进入GRUB引导菜单,若GRUB菜单一闪而过,需先修改GRUB配置:编辑/etc/default/grub文件,将GRUB_HIDDEN_TIMEOUT设为0删除该行,执行update-grub更新配置后重启。

  2. 编辑内核参数
    在GRUB菜单中选择“Advanced options for Ubuntu”,找到对应内核版本的条目(如“Ubuntu, with Linux 5.15.0-76-generic”),按e键进入编辑模式。

  3. 修改启动参数
    找到以linuxlinuxefi开头的行,在行尾添加init=/bin/bash(Ubuntu/Debian)或rd.break(CentOS 7+,需后续执行switch_root /sysroot),按Ctrl+X启动。

  4. 重置密码
    系统会以只读模式挂载根分区,需先重新挂载为读写模式:

    mount -o remount,rw /  # Ubuntu/Debian
    # 或 CentOS 7+:switch_root /sysroot

    使用passwd命令修改root密码:

    passwd root
    New password: [输入新密码]
    Retype new password: [确认新密码]

    若修改/etc/shadow文件(如忘记passwd命令位置),可将root密码字段置空:

    linux中如何删除账户密码忘记

    sed -i 's/^root:[^:]*:/root::/' /etc/shadow
  5. 重启系统
    执行exec /sbin/initreboot -f重启,新密码即可生效。

普通用户密码丢失:管理员通过passwd命令重置

若普通用户忘记密码,且管理员(root)可正常登录,可直接使用passwd命令重置,无需复杂操作。

操作步骤

  1. 以root身份登录系统
    通过SSH或控制台登录root账户。

  2. 执行passwd命令

    passwd username  # 替换为目标用户名
    New password: [输入新密码]
    Retype new password: [确认新密码]

    命令执行成功后,用户即可用新密码登录。

GRUB修改失败:通过救援模式重置

若GRUB菜单被隐藏、损坏或无法编辑,需使用系统安装介质(如U盘/光盘)进入救援模式。

操作步骤(以CentOS为例)

  1. 通过安装介质启动
    将Linux安装U盘插入电脑,开机时按F12(或其他启动快捷键)选择U盘启动,进入安装界面。

    linux中如何删除账户密码忘记

  2. 进入救援模式
    选择“Troubleshooting”→“Rescue a CentOS Linux system”,按提示选择语言、键盘布局,系统会自动尝试挂载分区。

  3. 手动挂载根分区(若自动失败)
    使用fdisk -l查看磁盘分区,找到根分区(如/dev/sda2),手动挂载:

    mount /dev/sda2 /mnt/sysroot  # 挂载到救援环境的/mnt/sysroot
    chroot /mnt/sysroot            # 切换到系统根目录
  4. 重置密码
    执行passwd rootpasswd username修改密码,完成后退出:

    exit
    reboot                         # 重启系统

不同方法对比与注意事项

方法对比表

方法 适用场景 所需工具 优点 缺点
GRUB单用户模式 root密码丢失,物理访问系统 无需额外介质 操作简单,快速 需GRUB菜单可编辑,部分系统隐藏菜单
管理员passwd命令 普通用户密码丢失,root可登录 无需底层操作,安全 依赖root权限
救援模式 GRUB损坏或无法修改 安装介质(U盘/光盘) 稳定,可处理文件系统问题 需外部介质,步骤稍复杂

注意事项

  1. 文件系统检查:修改密码前,若系统异常,可执行fsck /dev/sdaXsdaX为根分区)检查文件系统完整性。
  2. SELinux兼容:CentOS/RHEL等开启SELinux的系统,重置密码后需执行restorecon /etc/shadow恢复文件安全上下文,否则可能无法登录。
  3. 备份重要文件:操作前建议备份/etc/shadow/etc/passwd,避免误操作导致系统无法启动。

FAQs

Q1: 忘记root密码后,GRUB菜单按Esc无法进入,怎么办?
A: 可尝试在开机时长按Shift键(部分主板需Esc),或通过BIOS/UEFI设置禁用“快速启动”(Fast Boot),若仍无法显示,需拆机进入BIOS,修改启动顺序为“仅Legacy模式”(部分旧主板),或制作GRUB修复U盘(如使用Boot-Repair工具)。

Q2: 重置密码后,用户无法SSH登录,提示“Permission denied”怎么办?
A: 首先检查SSH服务状态:systemctl status sshd,未启动则执行systemctl start sshd,其次检查/etc/ssh/sshd_configPasswordAuthentication是否为yes(默认为yes,若禁用需改为yes并重启SSH服务),若问题仍存在,可能是用户家目录权限错误,执行chown -R username:username /home/username修复权限。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/23892.html

(0)
酷番叔酷番叔
上一篇 2025年9月16日 10:17
下一篇 2025年9月16日 10:43

相关推荐

  • Linux系统如何支持触摸屏电脑?

    Linux系统对触摸屏电脑的支持已日趋成熟,从内核驱动到桌面环境均形成了完整的解决方案,本文将从底层机制、硬件识别、配置方法、桌面优化及常见问题解决等方面,详细阐述Linux如何支持触摸屏操作,Linux触摸屏支持的底层机制Linux对触摸屏的支持基于其输入子系统(Input Subsystem),该子系统负责……

    2025年9月25日
    4800
  • linux 如何进入sqlplus

    在Linux系统中进入SQLPlus是Oracle数据库管理和操作的常见需求,但具体操作需结合环境配置、用户权限及数据库状态等因素,以下是详细步骤和注意事项,帮助用户顺利进入SQLPlus环境,环境准备与基础检查在尝试进入SQLPlus前,需确保以下条件满足,否则可能导致连接失败或命令无法识别:Oracle数据……

    2025年9月29日
    5300
  • Tomcat启动失败?bin目录有妙招

    在Linux系统中停止Tomcat需要遵循正确的操作流程,以避免数据丢失或服务异常,以下是经过验证的几种可靠方法,适用于不同部署场景:通过Tomcat自带脚本停止(推荐首选)这是最安全的方式,利用Tomcat内置的shutdown.sh脚本实现平滑停止:# 执行停止命令./shutdown.sh# 验证是否停止……

    2025年7月8日
    6700
  • linux vi如何跳转行数

    Linux 的 vi 编辑器中,输入 :行号 可跳转到指定行

    2025年8月9日
    6000
  • Linux系统如何通过CGI接口实现固件的升级?

    在Linux系统中,通过CGI(Common Gateway Interface)实现固件升级是一种常见的Web管理方式,适用于嵌入式设备、路由器或需要远程升级的场景,本文将详细介绍环境搭建、CGI脚本开发、固件验证、安全措施及执行流程,确保升级过程稳定可靠,环境搭建:基础服务与工具准备首先需要搭建支持CGI的……

    2025年8月28日
    6500

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信