CentOS 6或7 启动故障修复及root密码破解
CentOS 6或7 启动故障修复及root密码破解
CentOS 6启动流程修复:
实验一:删除initramfs-2.6.32-754.el6.x86_64.img进行恢复
该文件很重要initramfs-2.6.32-754.el6.x86_64.img,作为启动系统的重要文件,加载文件系统的驱动。
开机按esc进入救援模式
chroot /mnt/sysimage # 切换根
mkinitrd /boot/ininramfs-`uname -r`.img `uname -r` # 修复此文件
sync sync sync # 同步到磁盘中
exit
reboot
实验二:破坏扇区的446字节,进行修复
准备
dd if=/dev/zero of=/dev/sda bs=1 count=446 # 破坏扇区的446字节
hexdump -C /dev/sda -n 512 -v # 查询出前446字节已被破坏
开机按esc进入救援模式
chroot /mnt/sysimage # 切换根
grub-install /dev/sda # 修复sda磁盘设备
sync sync sync # 同步到磁盘中
exit
reboot
实验三:破解CentOS 6密码
1.启动grub界面
2.输入e 添加1 进入单用户模式
3.输入passwd根据提示修改密码
4 reboot
CentOS 6添加单用户模式密码,无法破解:
[root@centos6 ~]# grub-crypt #创建单用户模式密码
Password: #输入口令
Retype password: #输入口令
$6$9M4MYaaShQLTXYAU$cIFuNc7SpKZw1NLCBG3/yoi6UHAWiMNxzBtDl3TGYzsmx3lRDjNRoRbNLEN8v8UsWldud2HHFRVqhbSFsqdly0
光盘破解CentOS 6密码:
进入救援模式
chroot /mnt/sysimage
vim /boot/gub/grub.conf # 注释掉passwd行即可
reboot
实验四:删除grub.conf
- 开机错误提示直接跳入到grub界面去输入内容:
kernel /vmlinuz-2.6.32-2754.e16.x86_64 root=/dev/sda2
initrd /initramfs-2.6.32-275.e16.86_64.img
- 临时进入机器内,修改配置文件,保存:
# vim /boot/grub/grub.conf
default=0
timeout=3
kernel /vmlinuz-2.6.32-2754.e16.x86_64 root=/dev/sda2
initrd /initramfs-2.6.32-275.e16.86_64.img
- 保存退出,修复完毕。
实验五:删除/boot/下的所有文件,需要光盘修复
- 开机按esc进入救援模式:去修复内核启动相关文件
mkdir /mnt/cdrom # 新建临时挂载文件
mount /dev/sr0 /mnt/cdrom # 挂载光盘
rpm -ivh /mnt/cdrom/Packages/kernel.... --root=/mnt/sysimage(指定安装路径) --force(强制安装)
- 修复grub文件
chroot /mnt/sysimage # 切换根
grub-install /dev/sda # 修复此文件
sync sync sync # 同步到磁盘中
exit
reboot
- 修复grub.conf文件
# vim /boot/grub/grub,conf
default=0
timeout=3
kernel /vmlinuz-内核版本 root=/dev/sda2
initrd /initramfs-内核版本.img
- 保存退出,修复完毕。
实验六:删除/boot/下的所有文件,且没有/etc/fstab文件,需要光盘修复
开机按esc进入救援模式:去修复
/etc/fstab文件mkdir /mnt/rootfs新建临时挂载文件将设备分别挂载,确定root根分区:
mount /dev/sda1 /mnt/rootfs # 确定/dev/sda1为boot分区
mount /dev/sda2 /mnt/rootfs # 确定/dev/sda2为/分区
mount /dev/sda3 /mnt/rootfs # 确定/dev/sda3为data分区
mount /dev/sda5 /mnt/rootfs # 确定/dev/sda5为swap分区
最后确定/dev/sda2为根分区进行挂载
mount /dev/sda2 /mnt/rootfs挂载/dev/sda2设备添加文件内容:
# vim /mnt/rootfs/etc/fstab
/dev/sda1 /boot ext4 defaults 0 0
/dev/sda2 / ext4 defaults 0 0
/dev/sda3 /data ext4 defaults 0 0
/dev/sda5 swap swap defaults 0 0
- 重启按esc进入救援模式:去修复内核启动相关文件
mkdir /mnt/cdrom # 新建临时挂载文件
mount /dev/sr0 /mnt/cdrom # 挂载光盘
rpm -ivh /mnt/cdrom/Packages/kernel.... --root=/mnt/sysimage(指定安装路径) --force(强制安装)
- 修复grub文件
chroot /mnt/sysimage # 切换根
grub-install /dev/sda # 修复此文件
sync sync sync # 同步到磁盘中
exit
reboot
- 修复grub.conf文件
# vim /boot/grub/grub,conf
default=0
timeout=3
kernel /vmlinuz-内核版本 root=/dev/sda2
initrd /initramfs-内核版本.img
- 保存退出,修复完毕。
CentOS 7故障修复流程:
实验一:删除/boot/grub2/下的文件进行修复:
进入救援模式:
然后切换根目录:
chroot /mnt/sysimage
- 生成grub2文件
grub2-install /dev/sda
- 将grub.cfg启动配置文件生成
grub2-mkconfig -o /boot/grub2/grub.cfg
sync sync sync sync 同步写入磁盘中
reboot
实验二:删除/boot/下的所有文件,需要光盘修复
进入救援模式rescue
切换根目录:
chroot /mnt/sysimage
- 进行临时挂载
mount /dev/sr0 /mnt
- 修复内核里边的相关启动文件
rpm -ivh /mnt/Packages/kernel-3.10.0-957.el7.x86_64.rpm --force
- 修复grub2文件内容
grub2-install /dev/sda
- 最后修复grub.cfg启动的相关配置文件
grub2-mkconfig -o /boot/grub2/grub.cfg
sync sync sync sync 写入磁盘保存
reboot重启。
实验三:破解CentOS 7密码
- 首先重启,在grub菜单界面,按
↑↓键,选择第一项,同时按下e键进行编辑。

- 在此界面找到
ro替换为rw init=/sysroot/bin/sh,修改完成之后,按下Ctrl+x进入紧急模式
原理:启动一个shell环境,系统并没有真正启动。



- 切换根目录
chroot /sysroot,修改密码。
Linux命令需要在根目录下执行。
chroot,即 change root directory (更改 root 目录),在使用 chroot 之后,系统的目录结构将以指定的位置作为/位置,系统读取到的目录和文件将不在是旧系统根下的而是新根下(即被指定的新的位置)的目录结构和文件。

修改密码后,如果开启了selinux服务,需要在根下创建文件/.autorelabel,最后退出跟系统,重启。
chroot /sysroot
passwd
touch /.autorelabel
exit
reboot
CentOS 7添加grub引导加载程序密码,无法破解:
[root@centos7 ~]# grub2-setpassword # 创建密码命令
[root@centos7 ~]# cat /boot/grub2/user.cfg # 保存密码的文件位置
GRUB2_PASSWORD=grub.pbkdf2.sha512.10000.978E5C106D6A102F6912FF51C37CE674483C0AAE52B84EC4DBB6C08AF818CE83BCA8A9743F31A72AA0BD0AB644A66D34AA774EEDDF913DE22C71A6C4A2826860.2B0701EF272ADE6E518EAA613F966F3C1F5C1150B2F61A04FCC34D2588A1FAB2F75922AB8A5DC5C02AA1A84F5EEE919F8C3DE5526FBCB46EA85082EE98CD6919
[root@centos7 ~]# mv /boot/grub2/user.cfg /root # 移走密码文件,密码即失效。
CentOS 6或7 启动故障修复及root密码破解的更多相关文章
- centos LAMP第四部分mysql操作 忘记root密码 skip-innodb 配置慢查询日志 mysql常用操作 mysql常用操作 mysql备份与恢复 第二十二节课
centos LAMP第四部分mysql操作 忘记root密码 skip-innodb 配置慢查询日志 mysql常用操作 mysql常用操作 mysql备份与恢复 第二十二节课 mysq ...
- CentOS 6.5在grub界面下更改root密码
想要更改CentOS 7 root的密码或者忘记了root的密码的时候可以在grub界面下更改root的密码. 百度了很多内容,更多方法都是适用于centos6及以前版本的,终于找到一个可以的. 1. ...
- centos 7 下进入单用户模式修改root密码
centos7进入单用户模式修改root用户密码 在工作中可能会遇到root密码忘记,那么这里就要进入单用户模式下了. 在重启电脑之后 时间:2015-05-13 10:42来源:blog.51cto ...
- [置顶] CentOS release 5.4 (Final)重置root密码(图文)
- CentOS单用户模式下修改ROOT密码和grub加密
Linux 系统处于正常状态时,服务器主机开机(或重新启动)后,能够由系统引导器程序自动引导 Linux 系统启动到多用户模式,并提供正常的网络服务.如果系统管理员需要进行系统维护或系统出现启动异常时 ...
- centos单用户模式:修改ROOT密码和grub加密
centos单用户模式:修改ROOT密码和grub加密 CentOSLinux网络应用配置管理应用服务器 Linux 系统处于正常状态时,服务器主机开机(或重新启动)后,能够由系统引导器程序自动引导 ...
- CentOS 单用户模式:修改Root密码和grub加密[转]
原文出处: http://zhengdl126.iteye.com/blog/430268 Linux 系统处于正常状态时,服务器主机开机(或重新启动)后,能够由系统引导器程序自动引导 Linux 系 ...
- Centos 7 忘记密码的情况下,修改root密码
应用场景 linux管理员忘记root密码,需要进行找回操作. 注意事项:本文基于centos7.4环境进行操作,由于centos的版本是有差异的,继续之前请确定好版本 操作步骤 一.重启系统,在开机 ...
- Centos忘记root密码重置
entos6.5忘记root密码重置 一,启动服务器按e键 二,按e键选择第二项 三,在ro root前输入single回车保存 四,回到前面一个界面按b键启动 不用密码即可启动输入passwd修改r ...
随机推荐
- vue回调接口
1.微博回调接口 1.1oauth/urls.py 中添加路由 urlpatterns = [ path('weibo/callback/', views.OauthWeiboCallback.as_ ...
- Python中判断字符串是否为数字、字母、标识符、浮点数、大小写、可打印的方法
1.判断s是否都是大写字母:s.isupper(): 2.判断s是否都是小写字母:s.islower(): 3.判断s中的每个单词首字母是否都是大写字母且其他位置无大写字母:s.istitle(),要 ...
- PyQt学习随笔:ListView控件的视图和数据模型分离案例
Qt 中view类控件的目的是实现数据和模型分离,控件展示数据,数据保存在数据存储中,数据存储中的数据改变了,则控件中展示的数据跟随改变.当设计时只指定了一个控件和一个数据存储关联时,这种分离虽然也能 ...
- js中的(function(){})()立即执行
( function(){-} )() 和 ( function (){-} () ) 是两种javascript立即执行函数的常见写法,要理解立即执行函数,需要先理解一些函数的基本概念. 函数声明. ...
- AT2688 [ARC080C] Young Maids
一道挺有意思的题目,在这里记录一下. 题目大意 给你一个长度为 \(n\) 的排列,每一次你可以取出相邻的两个数将其放在答案序列的开头,最后问你字典序最小的答案序列是什么. 题解 由于最后是求字典序最 ...
- 题解 CF1428F Fruit Sequences
\(\texttt{Bullshit}\) 蒟蒻 \(\texttt{7 min}\) 切 \(\texttt{F}\), 挽回了本一定掉分的局面/cy 分竟然还没有别人 5 题高 (本题解为目前 c ...
- 2020中国.NET开发者峰会近50场热点技术专题揭秘
简介 / Summary 2014年微软组织并成立.NET基金会,微软在成为主要的开源参与者的道路上又前进了一步.2014年以来已经有众多知名公司加入.NET基金会,微软,Google,AWS三大云厂 ...
- Python不同包之间调用注意事项
1.不同包之间调用,因为在不同文件夹下,引用的时候加上包名就可以了.运行时,在eclipse直接运行没有问题.但是在,命令行运行时出现找不到模块的错误.原因是,Python只搜索当前目录和内置模块以及 ...
- git+pycharm结合使用
Pycharm + git 进行结合使用 第一步:Pycharm配置本地安装的Git 测试框架的负责人: 编写好一套能用的基础框架代码 --- > 上传到公司远程仓库 --- 设置团队协作成员 ...
- Goldengate搭建
OGG进程 捕获进程(源端):捕获online redo log或者archived log中增量事务日志 传输进程(源端):把目标端落地的trail文件通过配置的路由信息传输到目标端 网络传输:tc ...