1,POST [power on self test]:
接通电源后,CPU通过出厂指定的地址读取代码,包括主板芯片上的ROM,测试内存,cpu风扇,显示设备等。此时无论如何,硬盘设备本身必须在硬件平台上被主板等组件识别到。硬盘设备可以是硬盘,U盘,光盘等
BOIS--Boot Sequence--主要设定启动次序(多个磁盘都可以启动OS)
加载磁盘设备第0磁道第0扇区[sector 0]----MBR
446bytes bootloader
:选定启动的OS,能自行识别分区文件系统(kernel文件只能放在基本磁盘分区上),调用相应的内核文件至内存RAM中。
Kernel文件在内存中压缩存放,其文件由两段组成,第一段能解压第二段文件。
64bytes 分区表
2bytes 特殊标记
tips:bootloader加载内核并为内核提供根的驱动模块文件(initrd -
被同时加载到内存中--内核把此文件当磁盘用-),此模块和kernel文件放在同一个基本磁盘分区上。
tips:安装程序在安装系统后能自动识别所需要的驱动模块打包做成文件。能让内核识别更多的硬件设备
2, MBR存在磁盘中,bootloader由OS设定安装,GRUB引导程序安装在bootloader中
GRUB引导阶段: /boot/grub/*
1st
stage: 位于MBR中,为了引导2nd stage
1.5
stage: 位于boot基本磁盘分区中,为识别内核文件所在的文件系统提供文件系统识别扩展
2nd
stage: 位于boot基本磁盘分区中,GRUB的引导程序
当stage2被加载时,GRUB根据请求的情况显示一个内核清单(/etc/grub.conf中定义)
Grub的功能
1、选择要启动的内核或系统;
能隐藏选择界面
2、交互式接口
e:
编辑模式
3、基于密码保护
启用内核映像;
定义在相应的title下
传递参数(进入编辑模式)
定义在全局段中
3,kernel文件自解压,内核运行initrd文件在内存中仿真的伪文件系统,加载驱动模块(运行/linuxrc或者/init脚本,sysroot下的真正根文件系统设备挂载到/下,初始根文件系统挂载到initrd/下,然后释放虚拟文件系统,挂载真正意义上的根目录文件系统并启动第一个用户级进程
init 进程
4,内核主动调用第一个进程/sbin/init。其主要功能是准备软件执行的环境,包括系统主机名,网络设置,语系处理,文件系统格式及其他服务的启动等。
init会读取/etc/inittab的配置文件。inittab定义了init的处理流程,其流程是:
1、取得runlevel即默认执行等级的相关等级
2、使用/etc/rc.d/rc.sysinit进行系统初始化,其主要工作是设置好整个系统的环境。
3、确认启动进入级别,通过/etc/rc.d/rc根据启动的级别来决定启动的服务选项,
4、执行用户自定义开机启动程序/etc/rc.d/rc.local
5、执行终端机模拟程序mingetty来启动login进程,等待用户登入