玩转linux之启动篇

  

 想要玩转linux,首先明白其启动流程,这里简单说明一下:

CentOS 6启动流程:

   POST –> Boot Sequence(BIOS) –> Boot Loader –> Kernel(ramdisk) –> rootfs–> switchroot–> /sbin/init–>(/etc/inittab, /etc/init/*.conf) –> 设定默认运行级别–> 系统初始化脚本rc.sysinit–> 关闭或启动对应级别的服务–> 启动终端

Boot Loader:

   bootloader是系统的启动加载器。通常情况下,引导程序都安装在bootloader中。以我们常见的grup为例,grub分为stage1,stage1.5,stage2。其中stage1的代码是直接存放在mbr中的。当BIOS将控制权传递给MBR后,stage1的代码就开始运行,它主要负责将stage1.5或者stage2的内容加载在内存中。stage2被加载到内存中后,就会读取grub的配置文件grub.conf。

想要玩转,我们就要先玩破坏,然后再修复,才可以。


首先stage1阶段:

  stage1的代码是直接存放在mbr中的,

MBR引导扇区共512bytes,其中:

    主引导程序(boot loader):446bytes, 可以安装引导加载程序

    主分区表(partition table):64bytes,记录整块硬盘分区的状态(16bytes: 标识一个分区)

    结束标识: 2 bytes, 55AA ,MBR区域的有效性标识;55AA为有效

我们可以使用命令来查看一下MBR的内容:

[root@CentOS-6 ~]# hexdump -C -n 512 /dev/sda

然后我们要破坏stage1,主要是破坏MBR中前446个字节,可以使用命令

[root@CentOS-6 ~]# dd if=/dev/zero of=/dev/sda bs=446 count=1

wKiom1fXUBDCg0cdAAAVTASCKfQ490.png

这样MBR前446个字节就全为0了,这时bootloader就已经被破坏,下面来重启试试看:)

重启系统后,stage1阶段没有正常启动,直接跳至光盘引导。。。

wKioL1fXVqehr0pOAASGAlXHzTo100.png

下面我们就要进入救援模式,来进行修复:

wKiom1fXVrfzNOj5AAQGfQRwzn4992.png

之后会有一些语言和键盘及网卡的选项,根据需要自主选择,再之后会出现Rescue选择界面,我们选择Continue继续。

wKiom1fXV-DBkOC3AAAlevc4WqQ596.png

再之后会有一些提示信息,ok继续,直至出现下图界面,我们选择start shell,ok继续

wKioL1fXWCXyFAfjAAAKD2mjF5I287.png

这样我们就会进入一些救援模式的shell,现在我们所在的位置,并不是我们系统的根,而是当前救援shell的根,所以我们首先要切换根目录,使用“chroot”命令:

wKioL1fXWuaB_inEAAAup-TWK9w903.png修复完成后,退出shell,选择reboot重启系统

wKiom1fXWx2gfyK8AAAZ85Z2dOw119.png

wKioL1fXWy3Tr-CZAAAKlOqxRvk475.png

在系统重启后,系统会修复,需要等待一段时间,切勿强制退出

wKioL1fXW4zC0eyCAABMoo4s68k750.png

OK,这样stage1的破坏与修复我们就学会了,是不是很简单,下面我们将stage1.5给破坏了,看看怎么修复。stage1.5是为stage2提供驱动的(在0柱面1扇区后面的63个扇区中存储)        

首先我们看看stage1.5的位置

[root@localhost6 ~]# hexdump -C -n 1024 /dev/sda

wKioL1fXYLzADg0oAAAg8dTSEow894.png

我们摧毁stage1.5,而不摧毁stage1就需要跳过前512个字节

[root@localhost6 ~]# dd if=/dev/zero of=/dev/sda bs=512 count=2 seek=1

然后重启来试试看:

显示结果就是:黑屏。。。

这是因为stage1是正常的,他认为系统是存在的,但是到1.5阶段,找不到驱动,所以就卡在那里了。

所以我们修复的话还是需要进入的救援模式下,进行修复,步骤和修复stage1是完全一样的,这是因为

安装grub命令:

(1) grub-install

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

 命令格式:grub-install –root-directory=DIR /dev/DISK  

    注:这里的"–root-directory=DIR"是指定/boot目录的父目录,因为grub-install还可以复制GRUB相关文件到DIR/boot目录下。如果/boot的父目录为根目录,则可以省略。

(2) grub    交互式修复

grub> root (hd#,#)

grub> setup (hd#)

    注:这条命令,依赖于“/boot/grub”目录下的文件,如果文件丢失,请使用第一种方法。

   因为“grub-install”命令不仅能修复stage1 还可以修复stage1.5,所以1.5的修复步骤和1的完全一样,但这里我们就来使用第二种方法来修复一下1.5阶段,(进入救援模式的步骤参考前文)

wKioL1fXaD_y6ykWAAA5Grbjhi0227.pngreboot重启!

完工,还是这么简单。。。:)

   修复就是这么简单,下面我们来玩一个稍微复杂一点的,将stage1,stage1.5,stage2及/boot/grub目录全部破坏,然后来修复。

wKioL1fXb2eC6XjbAAA2lNe-BLc852.png

进入救援模式:然后执行以下操作:

wKioL1fXhUqAQNCnAAAsNlqhOHw850.pngwKiom1fXhMyAxb7bAAALC66aGB0671.png

然后保存退出,重启系统即可。

 

 再接再励越玩越大

实验:删除/boot 和/etc/fstab,恢复之

wKiom1fXpb2CDCknAAAVuUoGAGA741.png

进入救援模式,首先解决挂载问题,然后重启让系统重新读取fstab文件,重新挂载

wKioL1fXs8Gzx0yBAAAyUPK-jGU618.png

wKiom1fXthDxzxzbAAALzvPftBo570.png


wKioL1fXv6-D0jyRAAAFOrqVQUg702.png

reboot 重启,让系统重新挂载,重新进入救援模式:

wKioL1fXvPyBfwgaAAA_YbYIh_0573.png

wKiom1fXhMyAxb7bAAALC66aGB0671.png

重启系统,系统需要修复文件,需要稍等片刻。。。

进入系统后,即可重新更改/etc/fstab/ 重新设置系统挂载条件。

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

(0)
GrootGroot
上一篇 2016-09-26 07:44
下一篇 2016-09-26 07:44

相关推荐

  • 设计模式(六)桥连模式Bridge(结构型)

    1. 概述       在软件系统中,某些类型由于自身的逻辑,它具有两个或多个维度的变化,那么如何应对这种“多维度的变化”?如何利用面向对象的技术来使得该类型能够轻松的沿着多个方向进行变化,而又不引入额外的复杂度? 例子1:设想如果要绘制矩形、圆形、椭圆、正方形,我们至少需要4个形状类,但是如果绘制的图形需要具有不同的…

    Linux干货 2015-06-26
  • 谷歌三大核心技术(二)Google MapReduce中文版

    摘要 MapReduce是一个编程模型,也是一个处理和生成超大数据集的算法模型的相关实现。用户首先创建一个Map函数处理一个基于key/value pair的数据集合,输出中间的基于key/value pair的数据集合;然后再创建一个Reduce函数用来合并所有的具有相同中间key值的中间value值。现实世界中有很多满足上述处理模型的例子,本论文将详细描…

    Linux干货 2015-04-13
  • awk应用和systemd

    一:练习 1、求每班总成绩和平均成绩 name class score wang   1    100 zhang  2    90 li     1    80 2、为编译安装的httpd服务,实现service unit文件 3、破解centos7 口令 …

    Linux干货 2016-09-22
  • Linux三剑客之grep使用入门指南

    Linux的grep是一个具有强大功能的文本搜索工具,正确的学习和使用,能很大程度上提高工作效率,减轻运维工作所面临的压力。

    2017-09-09
  • 文件查找命令之find

    文件查找命令一共有两种,locate 和find ,那么他们在用法和功能上面有什么区别呢?     locate:查找速度快,模糊查找,遍历整个文件系统的目录到数据库中,然后在去数据库中查找,依赖于事先创建好的索引库,该数据库属于系统自动创建,定期自动更新,也可手动跟新,更新命令updatedb,更新数据库需要遍历整个根文件系统…

    Linux干货 2016-08-16
  • HA cluster应用—CoroSync+Pacemaker

    HA cluster应用——CoroSync v2 (quorum system)+Pacemaker (standalone daemon)+ crmsh/pcsh corosync简述: Corosync是OpenAIS发展到Wilson版本后衍生出来的开放性集群引擎工程。可以说Corosync是OpenAIS工程的一部分。OpenAIS从openais…

    2016-11-27