前段时间跟着团队在搞Linux系统的内核移植,涉及到很多模块的加载顺序问题(由于模块之前的强耦合,有点垃圾了),就学习了些Linux系统开机的基本流程,就算给刚刚入手的小伙伴些学习参考吧。
大致流程:
缩略语:
BIOS:(Basic Input Output System)基本输入输出系统,它是一组固化到计算机内主板上一个ROM芯片 上的程序,保存着计算机最重要的基本输入输出的程序、开机后自检程序和系统自启动程序,可从CMOS中读写系统设置的具体信息。
CMOS: (Complementary Metal Oxide Semiconductor)互补金属氧化物半导体存储器,是主板上一块可读写的RAM芯片,主要用拿过来保存当前系统的硬件配置和操作者对某些参数的设定。(放这是想和BIOS结合学习)
MBR: Master Boot Record,主要引导记录区。
Boot Loader:启动引导程序。
下面对各个步骤详细说明下:
1、BIOS加载
上电会自动加载 BIOS 的硬件信息并进行自我测试,并依据取得第一个可开机的装置,之后根据BIOS的配置找到第一个有引导程序的的设备。
2、读取执行第一个MBR内的Boot Loader
硬盘上的第1磁道第一个扇区被称为MBR,即主引导记录,512Kb,存放着预启动信息、分区表信息。在找到BIOS所指定MBR后,就会将Boot Loader复制到物理内存中。
而Boot Loader 就是在操作系统内核运行之前运行的一段小程序。通过这段小程序,我们可以初始化硬件设备、建立内存空间的映射图,从而将系统的软硬件环境带到一个合适的状态,以便为最终调用操作系统内核做好一切准备。
3、加载kernel
Boot Loader从指定磁盘上加载kernel, 把kernel解压缩到内存中, 利用kernel的功能, 开始测试与驱动硬件设备. 同时, kernel还会重新侦测一次硬件, 而不一定会使用BIOS侦测到的硬件信息. 至此, kernel开机接管BIOS后的工作.在此, 我们需要简单介绍一下Linux的kernel.
另外提一句,在Linux中, kernel存放在/boot 分区, 并且命名为vmlinuz。
4、运行/sbin/init程序,设定linux的run-level
kernel加载完成后,运行用户空间内的第一个应用程序/sbin/init,然后读取/etc/inttab文件,依据文件配置设定系统run-level
5、init执行进程rc.sysinit 的各个服务
Linux系统执行/etc/rc.d/rc.sysinit初始化脚本程序。
初始化包括:设置主机名、设置欢迎信息、激活Udex和seliux、挂载/etc/fstab文件中定义的所有文件系统、检测根文件系统、设置系统时钟、根据/etc/sysctl.conf文件来设置内核参数、激活LVM及软RAID设备、激活swap设备、加载额外设备的驱动程序、执行清理操作。
6、启动.ko文件
内核模块存放在/etc/sysconfig/modules目录中,将依据一定顺序加载内核模块。
7、执行 /etc/rc.d/rc.local 文件
在一切初始化工作之后,Linux留给用户进行个性化设置的地方。我们可以把想设置和启动的东西放到这个文件里。
8、运行/sbin/mingetty启动终端
接下来Linux就会启动终端或X Window. 至此, 整个系统开机流程完毕。