学习鸟哥的Linux私房菜笔记(17)——Linux引导流程
一、系统引导流程
第一步:固件fireware(CMOS/BIOS)——POST加点自检(与操作系统无关)
这一步主要是检查硬盘等硬件是否能正常工作
CMOS:是固化在主板上,详细:http://school.cfan.com.cn/news/cfannews/2007-06-06/1181111816d66664.shtml
BIOS:BIOS是固件的操作界面
CMOS是用来保存硬件参数信息的,而BIOS是用来修改这些参数的程序,简单地说:BIOS就是用来设置CMOS参数的手段,CMOS里面保存了BIOS设定的参数和结果,即“我们通过BIOS设置程序对CMOS参数进行修改”,比如我们需要修改系统启动顺序,在调整时,我们是通过BIOS设置为“光驱→硬盘→软驱”依次启动的,那么这个启动顺序的数据就保存在CMOS中。
hwclock硬件时钟(固化在固件中的时钟)
可以看到我的系统时钟和硬件时钟不同,下面来修改系统时钟和硬件时钟。
如果hwclock是正确的
可以用hwclock –help 查看参数
第二步:自举程序BootLoader(GRUB)——载入内核
MBR(mast boot record):位于磁盘的第一个柱面的第一个扇区
关于MBR详细请看:http://blog.csdn.net/hbrqlpf/article/details/3007863
/etc/grub.conf配置文件中记录关于系统内核的详细信息,我们进去看一下
系统内核版本是2.6.18
2:表示主版本号
6:表示次版本号(奇数表示测试版)
18:末版本号
后面还记录了内核文件的路径root=LABEL=/rhgb quiet initrd /initrd-2.6.18-128.e15.img
第三步:载入内核后(Kernel)——驱动硬件
启动进程(init)
系统首先会启动init进程,该进程启动后读取inittab文件,执行缺省运行级别,从而继续引导过程。在Linux系统中,init是第一个可以存在的进程,它的PID恒为1,但它必须向一个更高级的功能负责:PID为0的内核调度器(Kernel scheduler),从而获得CPU时间。
孤儿进程:父进程死掉后子进程还存在,则子进程被称为孤儿进程(系统检测到孤儿进程后会让init做父进程)。
僵尸进程:子进程死掉后父进程不知道,则子进程被称为僵尸进程。
第四步:读取执行配置文件/etc/inittab
0:表示关机
1:表示单用户模式(只有root账号,类似于Windows的安全模式,没有图形界面)
2:字符界面多用户模式,没有NFS服务
3:字符界面多用户模式,有NFS服务
4:待使用(自定义级别)
5:图形化的多用户模式(系统缺省级别)
6:表示重启
查看当前系统的运行级别(runlevel)
切换运行级别 ( init 级别)
二、inittab文件剖析
1、在inittab中所有条目采取以下格式
id:run-levels:action:process
id:标识符,一般为两位数字字母
run-level:指定运行级别,可以指定多个
action:指定运行状态
process:指定要运行的脚本/命令
2、action常用取值
initdefault:指定系统缺省启动的运行级别(例如在里面可以修改运行级别2后系统启动后进入字符界面)
sysinit:系统启动执行process中指定的命令。
wait:执行process中的命令,并等其结束后再执行其他命令
once:执行process中的命令,不等待其结束
ctrlaltdel:按下ctrl+alt+del时执行process指定的命令
powerfail:当出现电源错误时执行process指定的命令,不等待其结束
powerokwait:当电源恢复时执行process指定命令
respan:一旦process命令终止,便重新运行该命令
3、各个级别服务程序脚本
/etc/rc.d/init.d目录下包含各个运行级别的服务程序脚本
/etc/rc.d/rc[0123456].d分别存放对应运行级别的服务程序脚本的符号链接,链接到init.d目录中的相应脚本
K代表杀死该进程
S代表启动该脚本进程
K和S后面的数字代表执行顺序