linux操作系统的启动过程:
第一步: 首先BIOS初始化硬件设备和基本的硬件驱动。检测核心硬件设备的状况,设备良好则探测引导程序从usb,cdrom,硬盘。并将引导程序载入内存,将控制权交给MBR主引导记录。MBR大小为446B。
第二步:MBR进一步引导位于第0柱面第0磁道的grub引导程序中的第一段引导程序stage1_5。grub引导程序分为三部分,stage1,stage1_5,stage2。这三个文件位于/boot/grub下面。stage1实际上就是MBR的备份,stage1_5位于MBR的磁道上。/boot/grub下面的stage1_5也是磁道上的一个备份。*_stage1_5的大小约为15k。MBR将引导程序的第二部分*_stage1_5载入内存。
第三步:*_stage1_5可以识别linux文件系统,通过物理绝对路径再将stage2载入内存,至此grub引导程序全部载入内存,然后grub载入配置文件/boot/grub/grub.conf。到这里如果按下ESC键可以看到引导菜单。引导菜单就是在该配置文件中设置。
第四步:grub引导程序将/boot/initr*.img虚拟文件镜像和/boot/vmlinuz内核载入内存。虚拟镜像文件包含一些基本的系统驱动和工具。内核将根文件系统只读挂载。(只读挂载因为内核只需要加载存放在根上的所有系统驱动,如果读写挂载可能在根上生成一些文件,存在危险)。
第五步:内核将所有的驱动加载完毕,加载系统第一个init进程,将控制权暂时交给init。至此出现welcom to linux界面。
第六步:init加载所有的系统配置文件。/etc/init/rcS.conf /etc/inittab /etc/init/rc.conf /etc/rc?.d/* /etc/init/tty.conf /etc/serial.conf等文件。
第七步:init启动mingetty进程,读取配置文件/etc/init/tty.conf进入字符终端界面或者图形界面,至此整个系统完成启动。
以下介绍几个除段的排错方法,大家做个参考。
第一阶段排错:
1,MBR主引导记录被破坏,进入救援模式,打开一个shell运行命令grub-install /dev/sda1 修复MBR,stage1_5全部重新写入。
2,Superblock被损坏,进入救援模式,运行fsck /dev/sda1 修复。
3,如果删除stage1_5和stage2,grub依然可以完整引导,因为MBR中包含stage1_5和stage2的物理地址。
第二阶段排错:
1,grub引导菜单需要输入密码,进入救援模式,修改配置文件/etc/grub/grub.conf,将密码行去掉。
或者在内核的参数项目加一个选项 数字 1或者字母s 1和s的含义表示进入单用户级别。
第五阶段排错:
1,若init进程的配置文件缺失,编辑grub引导程序的菜单选项kernel字段,在内核参数项加入一个参数 init=/bin/bash 。这样可以将第一个加载的进程直接变为bash而不是init。之后再修复缺损文件。可以重新安装init程序。这时的根文件系统是只读挂载的,所以还必须重新读写挂载,mount -o remount,rw / .这样才可以修改。
2,init进程加载的/etc/rc/rc.local文件中可以放置命令,文件中的命令可以在init加载的过程执行,此处应注意恶意篡该。
3,init进程加载的配置文件/etc/inittab文件中确定了默认的进入模式,文件中的唯一语句为 id:5:initdefault:
数字5表示以图形界面多用户进入,0 表示关机,1表示单用户,2多用户无网络文件系统功能进入,3表示多用户字符界面,4为unused 5为X11 6为reboot .
所以在命令行中输入 init {0,1,2,3,4,5,6}可以进入不同模式。
4,init配置文件加载顺序:
/etc/inittab ---> /etc/rc.d/rc.sysinit -------> /etc/rc.d/rc------->/etc/rc?d/* 。
| || |
确定进入级别 || |
配置net,fsck检测filesystem ||
重新读写挂载根文件系统 | |加载或终止相应服务
相应等级的配置文件