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
下一篇 2017-04-02

相关推荐

  • 个人思想的转变及对学习的态度

    了解linux已经一年多了,但实际上学习的次数并不多。我是在部队的时候通过网络了解到linux,刚开始接触的是乌班图系统,感觉这个系统美化比较漂亮,就安装在虚拟机里进行各种操作,但是对命令是一窍不通的,都是通过百度粘贴复制各种命令,在复制的是同时我也感觉到头大,这个系统的输入、输出怎么都是字母出现在屏幕上,顿时就感到兴趣失去了一大半,再加上自己英语也不好,就…

    Linux干货 2018-03-26
  • mount挂载

    mount 1 挂载mount                                               &nb…

    Linux干货 2017-04-24
  • Linux程序包管理方式

    Linux程序包安装和管理方式共计三种:          一、[yum|dnf],通过官网或者其他开源网站提供的文件服务器,本机镜像源等途径进行安装。         二、rpm,通过官网或者其他开源网站通过…

    Linux干货 2016-08-29
  • DNS简单配置

    正向解析,反向解析,主从, 主:主配置文件:options {        listen-on port 53 { 127.0.0.1; 172.16.252.194; };  //监听的端口,即哪些主机可以进行访问        directory   &…

    Linux干货 2017-05-24
  • DNS的基本配置、子域授权与bind编译(第十八九天)

        DNS( Domain Name System)是“域名系统”的英文缩写,是一种组织成域层次结构的计算机和网络服务命名系统,它用于TCP/IP网络,它所提供的服务是用来将主机名和域名转换为IP地址的工作。     DNS利用类似于树形目录的结构,将主机名的管理分配在不同层…

    Linux干货 2016-06-12
  • Linux 系统中screen命令不能使用的解决办法,screen包的正确安装

           有些同学可能在安装完Linux发行版之后,发现screen功能不能实现,这是因为是实现该功能的包在安装系统的过程中没有安装上,这里我根据自己的经验介绍两种安装screen包的方法,用来你实现screen命令。 方法一、     条件:连网状态;   &nb…

    2017-07-12