CentOS Grub、BASH 故障、解决方法

简介:

Grub 常见的两种故障:Grub.conf 文件丢失、MBR 损坏 ( 不管恢复怎么样,还是先备份好吧 )

一、Grub.conf 文件丢失

shell > rm -rf /boot/grub/grub.conf ## 删除文件、模拟故障
shell > reboot

## 故障现象如下:

GNU GRUB verstion 0.97 (634k lower / 1046400k upper memory )
[ Minimal BASH-like line editing is supported. For the first word, TAB lists possible command completions. Anywhere else TAB lists the possible completions of a device/filename. ] grub>

## 就这个样子,无法登陆系统,下面是解决方法

grub> root (hd0,) # 输入 root (hd0,) 这时按 TAB 键会打印出系统上所有的分区 ( 注意在急救模式下不支持 TAB , 很伤~ )
Possible partitions are:
Partition num: , Filesystem type is ext2fs, partition type 0x83
Partition num: , Filesystem type unknown, partition type 0x82
Partition num: , Filesystem type is ext2fs, partition type 0x83

## 0, 1, 2 代表分区编号,上面显示有文件系统,分区类型,像 83 就是 Linux 普通分区,82 是虚拟分区 SWAP ( 硬盘分区时的知识 )
## 这里不分 IDE / SATA 什么的,都用 hd 代表,hd0 代表第一块硬盘,hd0,0 代表第一块硬盘的第一个分区,系统中是用 sda1 代表第一块硬盘的第一个分区

grub> root (hd0,)/ # 输入 root (hd0,)/ 这里按 TAB 键搜索内核在不在此分区上 ( boot 分区 ),如果有会输出下面信息 ( 试  的分区, 是交换分区就没必要试了 )
Possible files are: lost+found grub efi .VMlinuz-2.6.-.e16.x86_64.hmac System.map-2.6.-.e16.x86_64 config-2.6.-.x86_64 symvers-2.6.-.x86_64.gz VMlinuz-2.6.-.e16.x86_64 initramfs-2.6.-.e16.x86_64.img

## 如果可以看到 vmlinuz- 跟 initramfs- 字样,说明这就是我们想要的东西

grub> root (hd0,)/ # 下面是搜不到的显示, 仔细看看 ( 发现这是根分区哎~~ hd0, 是根分区,我们用的是 SATA , 所以根分区是 /dev/sda3 很有用 !)
Possible files are: lost+found boot dev proc sys var tmp etc root selinux lib64 usr bin home lib media mnt opt sbin srv .autorelabel grub> root (hd0,) # 绑定启动分区
Filesystem type is ext2fs, partition type 0x83 grub> kernel /VMlinuz-2.6.-.e16.x86_64 ro root=/dev/sda3 # 指定启动内核,ro 只读模式,root= 指定根分区, 一定要指对 ( 可能如果 boot 没有单独分区不指定也是可以的 ) grub> initrd /initramfs-2.6.-.e16.x86_64.img # 这是内核映像吧 ( kernel 、initrd 都是上面搜出来的,输入一点点按 TAB 可以补全 ) grub> boot # 启动系统,手动编写 grub.conf 或恢复备份 shell > vim /boot/grub/grub.conf default= # 启动哪个系统
timeout= # 等待时间
title CentOS 6.6 # 描述信息
kernel /VMlinuz-2.6.-.e16.x86_64 ro root=/dev/sda3 # 内核
initrd /initramfs-2.6.-.e16.x86_64.img # 启动映像

## 这里有个 vim 的用法,直接主机上 vim 是不可以用鼠标复制命令行内容的,那 kernel 跟 initrd 又那么长,不好记
## 方法:末行模式下输入 .! ls /boot/vmlinuz- 按 TAB 就可以补全了,这时按 Enter 键就可以将此条信息放到当前文件中

shell > reboot

## 这样就恢复成功了!还是记得备份吧

## 如果 kernel 没有指对根分区就会这样~ 还要重启系统,重新来过

dracut Warning: Signal caught!
?dracut Warning: Boot has faild. To debug this issue add "rdshell" to the kernel command line.
?Kernel panic - not syncing: Attempted to kill init!
?Pid: , comm: init Not tainted 2.6.-.e16.x86_64 #
?Call Trace:
[<ffffffff815292bc] ? panic+0xa7/0x16f
? [<ffffffff815292bc] ? do_exit+0xa7/0x16f
? [<ffffffff815292bc] ? fput+0xa7/0x16f
? [<ffffffff815292bc] ? system_call_fastpath+0xa7/0x16f?
?

二、MBR 损坏

shell > dd if=/dev/zero of=/dev/sda count= bs= # 覆盖 MBR , 模拟故障 ( /dev/sda 前  个字节是 MBR )
shell > reboot

## 故障现象如下:

Operating System not found # 基本就这样,会出现本地硬盘找不到系统、从 PXE 获取,DHCP xxxxxxxxxxxxx

## 解决方法:使用紧急救援模式修复

> 插入系统光盘,进入急救模式 ( 这个都会进吧,CentOS 直接选择,RedHat boot:linux rescue )

shell > grub # 进入 grub 模式

grub> root (hd0,) # 直接指定内核所在分区吧,没法 TAB ( 一定要想办法找到它, 例如:先 chroot /mnt/sysimage , 然后 df -HT 可以看到所有分区,假如 sda1 是启动分区,那么这里对应就是 hd0, 了 )

grub> setup (hd0) # 重新安装 MBR 到该磁盘,实际上就是 /dev/sda

grub> quit

shell > reboot

## 现在就可以成功进入系统了,MBR 已经修复

附加:BASH 故障的解决方法

shell > rm -rf /bin/bash # 删除 bash ,模拟故障
shell > reboot

## 故障现象如为:系统无法初始化,init 命令不存在,其实什么指令都不能执行
## 进入急救模式重新安装 bash

shell > mkdir /media # 直接在光盘系统中操作,因为这时无法 chroot 到 /mnt/sysimage
shell > mount /dev/sr0 /media # 挂载光盘镜像,/dev/sr0 代表光驱,如果是 IDE 接口应该是 /dev/hdc
shell > cd /media/Packages
shell > rpm -ivh --replacepkgs --root /mnt/sysimage bash-4.1.-.e16.x86_64.rpm # 将 bash 安装到 --root 指定根目录中 --replacepkgs 是替换原有包
shell > reboot

## OK ,故障已经修复!

上一篇:LeetCode 7. Reverse Integer


下一篇:1214 线段覆盖wiki oi