BIOS
基本输入输出系统(BIOS)是一组固化到计算机主板上的只读内存镜像(ROM)芯片上的程序,它保存着计算机最重要的基本输入输出的程序、系统设置信息、开机后自检程序和系统自启动程序。
MBR
如果使用MBR格式,操作系统将创建MBR(主引导记录扇区),MBR位于整块磁盘的0磁道0柱面1扇区,主要功能是操作系统对磁盘进行读写时,判断分区的合法性以及分区引导信息的定位。
主引导扇区总共为512字节,MBR只占了其中的446个字节,另外的64个字节为硬盘分区表(DPT),最后两个字节“55,AA”是分区的结束标志。
MBR是计算机启动最先执行的硬盘上的程序,只有512字节大小,所以不能载入操作系统的核心,只能先载入一个可以载入计算机核心的程序,成为引导程序。
GPT
全局唯一的标识符(GUID),正逐渐取代MBR成为新标准。它和统一的可扩展性固体接口(UEFI)相辅相成。UEFI用于取代老旧的BIOS,而GPT则取代老旧的MBR。
在GPT硬盘中,分区表的位置信息存储在GPT头中。出于兼容性考虑,第一个扇区同样有一个与MBR类似的标记,叫作受保护的主引导记录(PMBR)。
PMBR的作用是当使用不支持GPT的分区工具时,整个硬盘将显示为一个受保护的分区,以防止分区表及硬盘数据遭到破坏,而其中存储的内容和MBR一样,之后才是GPT头。
GRUB
GRUB可用于选择操作系统分区上的不同内核,也可用于向这些内核传递启动参数。它是一个多重操作系统启动管理器,用来引导不同系统。
Linux操作系统启动流程
1.加载BIOS
BIOS中包含硬件CPU、内存、硬盘等相关信息,包含设备启动顺序信息、硬盘信息、内存信息、时钟信息、即插即用特性等。
2.读取MBR
读取完BIOS信息,计算机将会查找BIOS所指定的硬盘MBR引导扇区,将其内容复制到0x7c00地址所在的物理内存中。被复制到物理内存的内容是bootloader,然后进行引导。
3.GRUB引导
GRUB启动引导器是计算机启动过程中运行的第一个软件程序,当计算机读取内存中的GRUB配置信息后,会根据其配置信息来启动硬盘中不同的操作系统。
4.加载kernel
计算机读取内存镜像,并进行解压操作。系统将解压后的内核放置在内存中,并调用start_kernel()函数来启动一系列的初始化函数并初始化各种设备,完成Linux核心环境的建立。
5.设定inittab运行等级
内核加载完毕,会启动Linux操作系统的第一个守护进程init,然后通过该进程读取/etc/inittab文件,/etc/inittab文件的作用是设定Linux的运行等级。运行级别如下:
6.加载rc.sysinit
读取完运行级别,Linux系统执行的第一个用户层文件/etc/rc.d/rc.sysinit,该文件功能包括设定path运行变量、设定网络配置、启动swap分区、设定/proc、系统函数、配置SELinux等。
7.加载内核模块
8.启动运行级别程序
根据之前读取的运行级别,操作系统会运行rc0.d到rc6.d中的相应的脚本程序,来完成相应的初始化工作和启动相应的服务。其中以S开头表示系统即将启动的程序,如果以K开头,则表示停止该服务,S和K后紧跟的数字为启动顺序编号。
9.读取rc.local文件
操作系统启动完相应服务之后,会读取执行/etc/rc.d/rc.local文件,可以将需要开机启动的任务加入到该文件末尾,系统会逐行去执行并启动相应命令。
10.执行/bin/login程序
执行/bin/login程序,启动到系统登陆界面,操作系统等待用户输入用户名和密码,即可登录到shell终端,至此Linux操作系统完整流程启动完毕。