18-系统启动故障修复-实践

说明:重启时可以选择性在vmlinuz所在行末尾添加 selinux=0;或者直接编辑/etc/selinus/config文件,更改 SELINUX=disabled 关闭SELINUX。可以避免打标签,节省启动时间

以下操作都需要进入bootloader引导加载项修改内核启动参数,在vmlinuz所在行末尾添加一个启动选项
如何进入bootloader引导加载项?
对于CentOS6:

POST加点自检后由MBR找到bootloader开始引导Grub之前的画面:
18-系统启动故障修复-实践

此时按任意键进入启动菜单:

按e键编辑:
18-系统启动故障修复-实践

按下箭头键选择vmlinuz所在行,再按e键进入编辑:
18-系统启动故障修复-实践
TAB键可补全,Esc键取消修改,Enter键接受修改并继续启动。
对于CentOS7:

按任意键进入启动菜单:
18-系统启动故障修复-实践

按e键编辑:
18-系统启动故障修复-实践

按下箭头键向下翻到vmlinuz所在行:
18-系统启动故障修复-实践

Ctrl+x键接受修改并继续启动,Ctrl+c启动命令行,Esc键取消修改并返回上级菜单,TAB键列出可用的补全列表。
忘记root密码
CentOS6:添加1或S或s或single,以单用户模式启动
CentOS7:
由于在/etc/inittab里设置了runlevel为6导致系统无限重启
CentOS6:
添加 3,以多用户模式启动,编辑/etc/inittab文件
CentOS7:
添加 rd.break,中断启动进入initramfs
默认挂载在/sys/目录下,编辑/etc/inittab文件
由于在crontab任务里设置了@reboot(注意:任何用户都有reboot执行权限)导致系统无限重启
CentOS7:
添加 rd.break,中断启动进入initramfs
默认挂载在/sys/目录下,编辑定义该任务的crontab文件
vim /sys/var/spool/cron/

以下修复操作都在光盘救援模式下执行,另外救援模式会尝试自动挂载分区,如果出现没有挂载的情况,首先需要挂载分区,对于MBR和bootloader的恢复而言主要是/和/boot,才能执行恢复操作。
破坏stage1,由于MBR前446字节数据损坏无法引导启动(dd id=/dev/zero of=/dev/sda bs=1 count=446) :grub-install
hexdump -C /dev/sda -n 512
chroot /mnt/sysimage
grub-install /dev/sda
hexdump -C /dev/sda -v -n 512
如果不切根,可以这样执行:
grub-install –root-directory=/mnt/sysimage/ /dev/sda

但是这里有个BUG:
18-系统启动故障修复-实践

该BUG从2008年就存在了: https://bugzilla.redhat.com/show_bug.cgi?id=429785
解决方法就是创建一个软链接:ln -s /usr/sbin/grub /sbin/grub
再执行:grub-install –root-directory=/mnt/sysimage /dev/sda

破坏stage1.5,/boot/grub/*1_5 (dd id=/dev/zero of=/dev/sda bs=1 count=14000 seek=512,意即搜寻目标位置从512bytes字节后开始操作)
注意:该dd破坏必需在手动执行过grub-install后才有效,因为只有手动执行过grub-install /dev/sda,grub的stage1.5的数据出现于MBR所在的512bytes之后的27个扇区内(513-14000bytes区间,总共13.5Kbytes)

hexdump -C /dev/sda -n 14000     #十六进制查看磁盘前14000字节的数据(注意到512bytes后的数据都已被dd命令成功清空,置为零)
18-系统启动故障修复-实践

方法1:
chroot /mnt/sysimage
grub-install /dev/sda
方法2:
df -h
grub
grub> root (hd0,0)     #假如/boot分区位于第一块硬盘的第一个分区

grub> setup (hd0)     #需要/boot/grub/*1_5备用文件
18-系统启动故障修复-实践

如果/boot/grub/*1_5备用文件不存在,这种方法不会修复成功:(对比上图,下图中提示e2fs_stage1_5文件不存在,如果用命令 “hexdump -C /dev/sda -n 14000” 查看,512字节后数据依然为零,说明并未将属于stage1.5的27个扇区的数据嵌入磁盘(hd0))
18-系统启动故障修复-实践


破坏stage2,由于/boot/grub/grub.conf内容有误无法引导启动
df -h
fdisk -l
chroot /mnt/sysimage
# grub2-mkconfig -o /boot/grub/grub.conf     #CentOS7可直接执行该命令重新生成grub配置文件
#手动执行grub命令启动
root (hd0,0)
kernel /vmlinuz<TAB键补全>  root=/dev/sda2
initrd /initramfs<TAB键补全>
boot
#进系统后再编辑/boot/grub/grub.conf配置文件即可

kernel行若未指明root=/dev/</partition> 会报错如下:
18-系统启动故障修复-实践


删除初始化内存盘文件导致无法进入系统(rm -f /boot/initramfs-*.img ):mkinitrd制作initramfs
18-系统启动故障修复-实践

chroot /mnt/sysimage
mkinitrd /boot/initramfs-`uname-r`.img `uname -r`

删除内核文件导致无法进入系统 (rm -f /boot/vmlinuz-* ):从光盘的kernel包解压出vmlinuz文件
18-系统启动故障修复-实践

mkdir /mnt/cdrom
mount /dev/sr0 /mnt/cdrom
cp /mnt/cdrom/Packages/kernel-*.rpm  /mnt/sysimage/root/
cd /mnt/sysimage/root/
rpm2cpio kernel-*.rpm | cpio -idv  ./boot/vmlinuz-2.6.32-642.el6.x86_64
或者:
cp /mnt/cdrom/isolinux/vmlinuz  /mnt/sysimage/boot/vmlinuz-`uname -r`

删除/boot/grub(rm -rf /boot/grub/)

chroot /mnt/sysimage/

grub-install /dev/sda
18-系统启动故障修复-实践

cd  /mnt/sysimage/boot/grub/
vim grub.conf
default=0
timeout=3
tile centos
root (hd0,0)
:r!ls /boot/vmlinuz /boot/initramfs.img

删除/boot(rm -rf /boot)
18-系统启动故障修复-实践

方法1:
chroot /mnt/sysimage
df -h
mount /dev/cdrom /mnt
#重新强制安装内核
rpm -ivh /mnt/Packages/kernel-* –force|–replacepkgs
grub-install /dev/sda
vim /boot/grub/grub.conf     #手写grub.conf
default=0
timeout=3
title centos6
root (hd0,0)
kernel /vmlinuz root=/dev/sda2
initrd /initramfs-.img
方法2:
chroot /mnt/sysimage
df -h
mkdir /mnt/cdrom
mount /dev/cdrom /mnt/cdrom
cp /mnt/cdrom/isolinux/vmlinuz /boot/vmlinuz
mkinitrd /boot/initramfs.img `uname -r`
grub-install /dev/sda
vim /boot/grub/grub.conf     #手写grub.conf
default=0
timeout=3
title centos
root (hd0,0)
kernel /vmlinuz root=/dev/sda2
initrd /initramfs.img

由于在/etc/fstab里设置了某个必需自检的设备损坏导致无法进入系统
vim /mnt/sysimage/etc/fstab    #将该损坏的设备的自检对应值设为0

删除/etc/fstab,普通分区(rm -rf /etc/fstab)
18-系统启动故障修复-实践

#恢复/etc/fstab文件
fdisk -l     #根据分区大小,猜测分区
blkid
mkdir /mnt/tmp
mout /dev/sda2 /mnt/tmp     #尝试挂载各个分区
ls /mnt/tmp     #通过内容猜测分区原来的挂载点
vi /mnt/root/etc/fsatb
/dev/sda1 /boot     ext4 defaults 0 0
/dev/sda2 /     ext4 defaults 0 0 
/dev/sda3 /home    ext4 defaults 0 0
/dev/sda4 swap 
#按猜测到的状态挂载分区
mkdir /mnt/root
mount /dev/sda2 /mnt/root
mount /dev/sda1 /mnt/root/boot

删除/boot/和/etc/fstab,普通分区(rm -rf /boot/ /etc/fstab)
#先恢复/etc/fstab文件
fdisk -l     #根据分区大小,猜测分区
blkid     #
mkdir /mnt/tmp
mout /dev/sda2 /mnt/tmp     #尝试挂载各个分区
ls /mnt/tmp     #通过内容猜测分区原来的挂载点
vi /mnt/root/etc/fsatb
/dev/sda1 /boot     ext4 defaults 0 0
/dev/sda2 /     ext4 defaults 0 0 
/dev/sda3 /home    ext4 defaults 0 0
/dev/sda4 swap 
#按猜测到的状态挂载分区
mkdir /mnt/root
mount /dev/sda2 /mnt/root
mount /dev/sda1 /mnt/root/boot
#再恢复/boot
#启动后查看
fdisk -l
mount
df -h

删除/boot/和/etc/fstab,逻辑卷LVM(rm -rf /boot/ /etc/fstab)
#恢复/etc/fstab
lvs     #查看lv信息:vg和lv名字
vgchange -ay     #激活所有卷组
ls /mnt/sysimage
vim /mnt/sysimage/etc/fstab
/dev/vg0/root     /     ext4 defalults 0 0 
/dev/vg0/var     /var/     ext4 defaults 0 0
/dev/vg0/usr     /usr     ext4 defaults 0 0
/dev/sda1     /boot     ext4 defaults 0 0
/dev/vg0/swap swap swap defaults 0 0
#挂载分区
mkdir /mnt/root
mount /dev/vg0/root /mnt/root
mount /dev/sda1 /mnt/root/boot
mount /dev/vg0/var /mnt/root/var
mount /dev/vg0/usr /mnt/root/usr
#恢复/boot
mkdir /mnt/cdrom
mount /dev/cdrom /mnt/cdrom
cp /mnt/cdrom/isolinux/vmlinuz /boot/vmlinuz
mkinitrd /mnt/root/boot/initramfs.img `uname -r`
vim /boot/grub/grub.conf     #手写grub.conf
default=0
timeout=3
title centos
root (hd0,0)
kernel /vmlinuz root=/dev/sda2
initrd /initramfs.img
删除/sbin/init(rm -rf /sbin/init)
在vmlinuz所在行末尾添加 init=/bin/bash
从另外一个系统拷贝/sbin/init文件过来

原创文章,作者:Leion,如若转载,请注明出处:http://www.178linux.com/72341

(0)
LeionLeion
上一篇 2017-04-02 20:29
下一篇 2017-04-02 21:10

相关推荐

  • 【听说要写一篇文章,我觉得标题比较长的人一定特别帅。】

    我叫小问。 计划是学好马哥所教授的知识。 目标是找到一份好工作!

    Linux干货 2016-10-23
  • systemd

    systemd的新特性(centos 7) 系统引导时实现服务并行启动 按需激活进程,在此之前可以让进程处于半活动状态 系统状态快照:能够自我保存当前系统上没一个用户空间的进程运行状态快照,将来可以迅速恢复到某一种状态,因此用户空间有了时间机器。可以回滚到过去某一时刻的状态 内在的基于依赖关系定义的服务控制逻辑 对与systemd来讲,引入了一个新的核心概念…

    Linux干货 2016-09-23
  • rpm软件包管理

    一:二进制应用程序组成部分 二进制文件(which command)、库文件(ldd `which command`)、配置文件(.conf)、帮助文件(.README)等 二:rpm包文件的组成 rpm文件、rpm元数据(如名称、依赖性关系等)、安装或卸载时运行的脚本 三:rpm包数据库: 1.组成部分(通过 ls /var/lib/rpm 来查…

    2017-08-13
  • OpenSSL

    一、什么是OpenSSL 在电脑网络上,OpenSSL是一个开放源代码的软件库包,应用程序可以使用这个包来进行安全通讯,避免窃听,同时确认另一端连接者的身份。这个包广泛被应用在互联网的网页服务器上。其主要库是以C语言所写成,实现了基本的加密功能,实现了SSL与TLS协议。 OpenSSL由三部分组成:     libencryp…

    Linux干货 2016-04-25
  • GRUB

    什么是GRUB GRUB(boot loader):grub:GRand Unified Bootloader     有两个版本:grub 0.x:grub legacy经典版;grub 2.x grub legacy:主要运行分三个阶段 stage1(第一阶段):安装在mbr中 stage1.5(第1.5阶段):存…

    Linux干货 2016-09-21
  • 简单路由实验

    今天学习了路由相关的基础知识,为了加深印象,做了如下的一个实验。根据下面的网络拓扑图分别配置两台PC和路由,以实现PC1和PC2能够互相ping通。实验环境为VM虚拟机 在实验开始前,我们需要在路由添加两块网卡,PC机添加一块网卡,此实验网卡的链接方式是桥接,一共需要4台虚拟机,两台做PC机,两台做路由器 1、R2路由器的配置 [root@linuxpao&…

    Linux干货 2016-09-05