Linux操作系统启动流程

一、操作系统启动概念


        不论是Windows还是Linux操作系统,底层设备一般均为物理硬件,操作系统启动之前会对硬件进行检查,然后硬盘引导启动操作系统。

1.1 BIOS(基本输入输出系统)

        基本输入输出系统(Basic Input Output System,BIOS)是一组固化到计算机主板上的只读存储镜像(Read Only Memory image,ROM)芯片上的程序,它保存着计算机最重要的基本输入输出的程序系统设置信息开机后自检程序系统自启动程序。其主要的功能是为计算机提供最底层的、最直接的硬件设置和控制。


        全新硬盘在使用前必须进行分区格式化,硬盘分区初始化的格式主要有两种,分别是MBR格式GPT格式

1.2 MBR(主引导记录扇区)

        如果使用MBR格式,操作系统将创建主引导记录扇区(Main Boot Record,MBR),MBR位于整块硬盘的0磁道0柱面1扇区,主要功能是操作系统对磁盘进行读写时,判断分区的合法性以及分区引导引导信息的定位。

        主引导扇区总共为512Byte,MBR只占其中446Byte,另外的64Byte为硬盘分区表(Disk Partition Table,DPT),最后2Byte“55”,“AA”是分区的结束标志。
在这里插入图片描述
        在MBR硬盘中,硬盘分区信息直接存储于主引导记录中,同时主引导记录还存储着系统的引导程序(如上图所示)。

        MBR(Main Boot Record)是计算机启动最先执行的硬盘上的程序,只有512字节,因而不能够载入计算机核心的程序——引导程序

        因为MBR分区标准决定了MBR只支持在2TB以下的硬盘,对于多余空间只能浪费。为了能支持使用大于2TB硬盘空间,微软和英特尔公司在可扩展固件接口(Extensible Firmware Interface,EFI)方案中开发了全局唯一的标识符(Globally unique identifier,GUID),进而全面支持大于2TB硬盘空间在企业中使用。

1.3 GPT

        全局唯一标识符(GUID),正在逐步取代MBR成为新标准,它和统一的可扩展固件接口(Unified Extensible Firmware Interface,UEFI)相辅相成。UEFI用于取代老旧的BIOS,而GPT则取代老旧的MBR。

        之所以称为“GUID分区表”,是因为驱动器上的每个分区都有一个全局唯一的标识符。


        在GPT硬盘中,分区表的位置信息存储在GPT头中。出于兼容性考虑,第一个扇区同样有一个与MBR类似的标记——受保护的主引导记录(Protected Main Boot Record,PMBR)。其作用是当使用不支持GPT的分区工具时,整个硬盘将显示为一个受保护的分区,以防止分区表以及硬盘数据遭到损坏,其中存储的内容和MBR一样,之后才是GTP头。

        GTP支持2T以上磁盘,如果使用Fdisk分区,最大只能建立2TB大小的分区,创建大于2TB的分区,需要使用Parted,同时必须使用64位操作系统。
        Mac、Linux系统都支持GPT分区格式;windows 7/8 64bit、windows server 2008 64bit支持GTP。
GPT分布区表

1.4 GRUB(GNU项目的多操作系统启动程序)

        GNU项目的多操作系统启动程序(GRand Unified BootLoader,GRUB),可以支持多操作系统的引导,它允许用户可以在计算机上同时拥有多个操作系统,并在计算机启动时选择用户自己希望的操作系统。

        GRUB可用于选择操作系统分区上的不同内核,也可以像这些操作系统的内核传递启动参数。
        Linux常见的引导程序包括:LILO、GRUB、GRUB2、CentOS 7 Linux,默认使用 GRUB2 引导程序,引导系统启动。
GRUB引导流程

        GRUB2是基于GRUB开发成更加安全强大的多系统引导程序,最新Linux发行版都是以其作为引导程序。GRUB2采用了模块化设计、使得GRUB2核心更加精炼,使用更加灵活。

二、Linux操作系统启动流程

Linux系统启动流程

2.1 加载BIOS

        计算机电源加电自检,首先加载BIOS,BIOS中间包含硬件CPU、内存、硬盘等相关信息,包含设备启动顺序、硬盘信息、内存信息、时钟信息、即插即用(Plug-and-Play)特性。加载完BIOS信息,计算机将会根据顺序进行启动。

2.2 读取MBR

        读取完BIOS信息,计算机将会查找BIOS所指定的硬盘MBR引导扇区,将其内容复制到0x7c00地址所在的物理内存中。被复制的内容——Boot Loader,然后进行引导。

2.3 GRUB引导

        GRUB启动引导器是计算机启动过程中运行的第一个软件程序,当计算机读取内存中的GRUB配置信息后,会根据其配置信息来启动硬盘上不同的操作系统。

2.4 加载Kernel

        计算机读取内存映像,并进行解压缩操作,屏幕一般会出现“Uncompressing Linux”的提示,当解压缩内核完成后,屏幕会输出“OK,booting the kernel”。系统将解压后的内核放置在内存中,并调用“start_kernel()函数”来启动一系列的初始化函数,并初始化各种设备,完成Linux核心环境的建立。

2.5 设定Inittab运行等级

        内核加载完毕,会启动Linux操作系统的第一个守护进程init,然后通过该进程读取/etc/inittab文件,/etc/inittab文件的作用是设定Linux运行等级,Linux常见运行级别:

符号运行模式
0关机模式
1单用户模式
2无线网络支持的多用户模式
3字符界面的多用户模式
4保留,未使用模式
5图像界面多用户模式
6重新引导系统,重启模式

2.6 加载rc.sysinit

        读取完运行级别,Linux系统执行执行的第一个用户层文件“/etc/rc.d/rc.sysinit”,该文件功能包括:设定 PATH 运行变量、设定网络配置、启动swap分区、设定/proc、系统函数、配置SeLinux等。

2.7 加载内核模块

        读取“/etc/modules.conf” 文件以及 “/etc/modules.d”目录下的文件来加载系统内核模块。该模块文件,可以后期添加、修改或删除。

2.8 启动运行级别程序

        根据之前读取的运行级别,操作系统会运行rc0.drc6.d中的相应的脚本程序,来完成相应的初始化工作和启动相应的服务。

运行级别服务

2.9 读取rc.local文件

        操作系统启动完相应的服务之后,会读取执行“/etc/rc.d/rc.local”文件,可以将需要开机启动的任务加入到该文的末尾,系统会逐条去执行并启动相应的命令。如下图所示:
开机运行加载文件


2.10 执行/bin/login程序

        执行“/bin/login”程序,启动到系统登陆界面,操作系统等待用户输入用户名和密码,即可登录到Shell终端。至此,Linux操作系统完成流程启动完毕。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值