Centos 系统引导损坏修复、密码破解与加密

Centos 6

实验环境:VMware Workstation Pro 14(试用版)

系统平台:

CentOS release 6.9 (Final)       内核  2.6.32-696.el6.x86_64



ramdisk(ramfs)丢失损坏

 内核中的特性之一:使用缓冲和缓存来加速对磁盘上的文件访问,并加载相应的硬件驱动

没有此文件,系统无法加载 / 分区,也就无法启动系统。

CentOS 5 文件名: initrd

CentOS 6,7文件名: initramfs


当系统的ramfs文件丢失或损坏时,系统启动时表现为

修复如下:

进入救援模式,重新生成ramdisk文件即可。

为当前正在使用的内核重新制作ramdisk文件,以下2种指令都可以。

# mkinitrd initramfs-`uname -r`.img `uname -r`

# dracut initramfs-`uname -r`.img `uname -r`


GRUB相关

 MBR:

446: bootloader, 64: 分区表, 2: 55AA

 GRUB:

阶段

存放位置

作用

stage1

MBR的446字节内

MBR引导

stage1_5

MBR之后的27个扇区

让stage1中的bootloader能识别stage2所在的分区上的文件系统,这个阶段可以加载驱动

stage2

/boot/grub(grub2)

grub的核心功能

stage1是以二进制存放于磁盘,并不是文件形式。


/boot/grub下的文件为:

主要是驱动与grub配置文件。这个目录下的文件只保留grub.conf的时候,系统是可以正常启动的


stage1破坏修复


stage1也就是bootloader所在,

模拟破坏(请不拿生产中的机器来做试验,本人不负责任)

#dd if=/dev/zero of=/dev/sda bs=1 count=446

系统启动时表现为


修复如下:

1.进入救援模式

2.启动一个shell

3.切换至原系统的根目录,一般救援模式进来的时候会提醒.(假如能找到/文件系统)

# chroot /mnt/sysimage

4.安装grub

方法(1) grub-install

安装grub stage1和stage1_5到/dev/DISK磁盘上,并复制GRUB相关文件到 DIR/boot目录下

grub-install  /dev/DISK .注意,是磁盘而非分区。--root-directory=DIR 参数可选

此方法会一并重新生成/boot/grub下除了grub.conf之外的文件

方法(2) grub

grub> root (hd#,#)

grub> setup (hd#)  

可以看到系统已经写入GRUB信息至MBR


第2种方法修复时,需要/boot/grub下有这些文件

# ls -1

device.map  e2fs_stage1_5 fat_stage1_5 ffs_stage1_5 grub.conf iso9660_stage1_5 jfs_stage1_5

menu.lst minix_stage1_5 reiserfs_stage1_5 splash.xpm.gz stage1 stage2 ufs2_stage1_5

vstafs_stage1_5 xfs_stage1_5

5.重启系统

#exit 并reboot



开机直接出现grub>


修复如下:

grub> root (hd#,#)  root目录指的是/boot分区所在的磁盘位置。

grub> setup (hd#)  

小提示:root (hd0,然后按tab键补全,会有如下显示

输入kernel /vm 按tab键如果可以补全则说明是正确的,接着输入ro root=/dev/sda1 回车.注意(hd0,0)=/dev/sda1 (hd0,1)=/dev/sda2如图

接着输入initrd /ini 按tab键补全,回车

输入boot命令,这时系统会重新启动



stage1.5破坏修复

模拟破坏

# dd if=/dev/zero of=/dev/sda bs=1 count=13000 skip=512 seek=512

系统启动时表现为


修复如下:

进入救援模式

1.# chroot /mnt/sysimage

2.安装grub (上面有方法)

3.多输入几次sync

4.#exit并reboot



stage2破坏修复


grub.conf丢失

系统启动时表现为


修复如下:

进入救援模式

1.# chroot /mnt/sysimage

2.安装grub (上面有方法)

3.检查/boot/grub/grub.conf是否存在且正确

4.重启系统



内核文件被破坏

系统启动时表现为


修复如下:

进入救援模式

1.# chroot /mnt/sysimage

2.touch 一个文件 /boot检查磁盘是可写,如果为只读,mount -o remount,rw /dev/sdX /boot

3.如果挂载的救援模式是原ISO的DVD1的话,里面会有内核文件,如果没有DVD1光盘,请去其他地方下载同一内核版本的rpm包。

执行安装指令

# rpm -ivh /光盘位置或指定位置/Packages/kernel-2.6.32-696.el6.x86_64.rpm --force

4.重启系统



/sbin/init 丢失破坏

模拟破坏

# rm -rf /sbin/init

系统启动时表现为

此时输入什么都是报错误的


修复如下:

1.重启系统至引导菜单,注意按上下箭头,以免超时跳过去。按 e

2 在kernel一行中,按 e 编辑

使用 /bin/bash 代替sbin/init

按 b 启动系统

任意输入一条命令,如果能出来结果,表示 系统启用/bin/bash为第一个进程

3. 重新挂载 / 分区为 读写模式

#mount -o remount,rw /

4 挂载光盘

# mount /dev/sr0 /mnt

5.重新安装/sbin/init 。此执行文件对应的安装为upstart  各个操作系统版本不一样,注意即可。

# rpm -ivh /mnt/Packages/upstart-0.6.5-16.el6.x86_64.rpm --force

使用以下方法也能达到同样效果:

# rpm2cpio /mnt/Packages/upstart-0.6.5-16.el6.x86_64.rpm | cpio -idv ./sbin/init

# cp sbin/init /sbin/

6. # ls /sbin/init 是否已经生成。

7.直接按硬件按钮的重启

至此,修复完成



逻辑卷环境下 /boot分区破坏,/etc/fstab丢失

原先的系统是以LVM卷方式安装的

模拟破坏

# rm -rf /boot/ /etc/fstab

系统启动时表现为


修复如下:

进入救援模式

会提示

启动shell

1.#vgs 查看下VG卷

2. #fdisk -l找出原来系统的boot分区,带*号启动的应该是/boot

3.#lvdisplay查看LV卷状态,可以看到是未激活状态

4 .# vgchange -ay 激活VG卷

#lvdisplay查看LV卷状态,可以看到是已激活状态

#blkid 能看到分区文件系统和挂载路径和UUID

7.创建临时目录挂载找到的分区,确认/和/boot分区。注意,这里是支持TAB键补全的。

# mkdir /mnt/root

# mount /dev/VolGroup/lv_root /mnt/root

# mkdir /mnt/boot   正常情况,因为是使用rm -rf /boot 挂载时应该是没有任何文件的

# mount /dev/sda1 /mnt/boot

8 cat /etc/mtab 能看到目前挂载情况

9 创建原有系统的fstab ,注意这里生成的文件位置

#cat > /mnt/root/etc/fstab << eof

/dev/mapper/VolGroup-lv_root / ext4 defaults 0 0

/dev/sda1 /boot ext4 defaults 0 0

eof

10 #exit 选reboot

11.再次进入救援模式

现在救援模式能侦测到根系统了

按照向导开启shell

12 # chroot /mnt/sysimage

#lsblk 可以看出原有系统的挂载情况了

13 挂载光盘

# mkdir /mnt/cdrom

# mount /dev/cdrom /mnt/cdrom

14 安装内核

# rpm -ivh /mnt/cdrom/Packages/kernel-2.6.32-696.el6.x86_64.rpm --force

15 修复Grub

# grub-install /dev/sda

16 修复grub.conf

# vi /boot/grub/grub.conf   ,可以使用vi的命令这些功能

列出命令结果到当前编辑行的下一行,支持TAB补全

列出设备的UUID

最终写好的文件如下

#exit 重启

如果启用了selinux的话,系统会在第一次重启时进行配置、

第二次重新启动时,系统就正常了。之后再把把

17 把swap添加到fstab,并启用

UUID=8e0a6121-97d7-4c70-b113-bbe4cefe0380 swap swap defaults 0 0

# swapon -a

建议把fstab文件重新修正为使用UUID方式

至此,系统修复完成。



手动在grub命令行接口启动系统

grub> root (hd#,#)

grub> kernel /vmlinuz-VERSION-RELEASE ro

root=/dev/DEVICE

grub> initrd /initramfs-VERSION-RELEASE.img

grub> boot



root密码破解


方法1:

1.重启系统至引导菜单,注意按上下箭头,以免超时跳过去。

按 a ,健入以下字符,1代表是单用户模式

1, s, S或single都可以,之后直接回车启动系统

无需要输入密码就以root身份进入系统了,直接passwd root修改


方法2:

进入救援模式,chroot /mnt/sysimage 之后,直拉用passwd root修改


方法3:

进入救援模式,chroot /mnt/sysimage 之后,直接修改/etc/shadow ,把root的密码栏位清空。需要vi时加入wq!

不过,重启后注意尽快修改密码



grub加密

当然,既然有破解密码的,也有相应加强安全的.

将下面一行放入不同位置将会有不同的效果

password [--md5|--encrypted ] 加密的字符串

放在每个title之前行 : 启动grub菜单时进行进行认证

放在每个title之末尾行 : 启动选定的内核或操作系统时进行认证

生成grub口令

 grub-md5-crypt   对应的是--md5

 grub-crypt 对应的是--encrypted



Centos 7

实验环境:VMware Workstation Pro 14(试用版)

系统平台:

CentOS Linux release 7.4.1708 (Core)       内核  3.10.0-693.el7.x86_64


模拟破坏(请不拿生产中的机器来做试验,本人不负责任)

模拟stage1  stage1.5  stage2 阶段破坏

# dd if=/dev/zero of=/dev/sda bs=1 count=446

# dd if=/dev/zero of=/dev/sda bs=1 count=13000 skip=512 seek=512

# rm -rf /boot


修复如下:

1.进入救援模式

spacer.gif

spacer.gif

spacer.gif

系统发现根系统

spacer.gif

2. 切换至待修复的根系统

# chroot /mnt/sysimage

spacer.gif

查看到/dev/sda确实没有MBR信息

spacer.gif

3.修复Grub

# grub2-install  /dev/sda .注意,是磁盘而非分区

spacer.gif

4.安装内核

挂载光盘

# mount /dev/sr0 /mnt

如果挂载的救援模式是原ISO的DVD1的话,里面会有内核文件,如果没有DVD1光盘,请去其他地方下载同一内核版本的rpm包。

执行安装指令

# rpm -ivh /光盘位置或指定位置/Packages/kernel-3.10.0-693.el7.x86_64.rpm --force

spacer.gif

5.生成gurb配置文件

注意这一步不能和第4步颠倒

# grub2-mkconfig -o /boot/grub2/grub.cfg

spacer.gif

6.保存并重启

# exit

#sync

#sync

#reboot


至此,系统修复完成。


Centos 7修复与Centos 6相差不大,只是使用的命令有些不同。



本文转自 ljpwinxp 51CTO博客,原文链接:http://blog.51cto.com/191226139/2058884

你可能感兴趣的:(Centos 系统引导损坏修复、密码破解与加密)