Linux系统启动过程

1.1、linux的启动过程

不管是 Windows 还是 Linux 操作系统,底层设备一般均为物理硬件,操作系统启动之前会对硬件进行检测,然后硬盘引导启动操作系统,如下为操作系统启动相关的各个概念:

1、BIOS

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

2、MBR

全新硬盘在使用之前必须进行分区格式化,硬盘分区初始化的格式主要由两种,分别是:
MBR 格式和 GPT 格式。
如果使用 MBR 格式,操作系统将创建主引导记录扇区(Main Boot Record,MBR),MBR 位于 整块硬盘的 0 磁道 0 柱面 1 扇区,主要功能是操作系统对磁盘进行读写时,判断分区的合法性以及分区引导信息的定位。
主引导扇区总共为 512 字节,MBR 只占用了其中的 446 个字节,另外的 64 个字节为硬盘分区表 (Disk Partition Table,DPT),最后两个字节“55,AA”是分区的结束标志。
在 MBR 硬盘中,硬盘分区信息直接存储于主引导记录(MBR)中,同时主引导记录还
存储着系统的引导程序,如图所示:
在这里插入图片描述
MBR 是计算机启动最先执行的硬盘上的程序,只有 512 字节大小,所以不能载入操作系统的核心,只能先载入一个可以载入计算机核心的程序,我们称之为引导程序。
因为 MBR 分区标准决定了 MBR 只支持在 2TB 以下的硬盘,对于后面的多余空间只能浪费。为了支持能使用大于 2T 硬盘空间,微软和英特尔公司在可扩展固件接口(ExtensibleFirmware Interface,EFI)方案中开发了全局唯一的标识符(Globally unique identifier,GUID),进而全面支持大于 2T 硬盘空间在企业中使用

3、GPT

全局唯一的标识符(Globally unique identifier,GUID),正逐渐取代 MBR 成为新标准。它和统一的可扩展固件接口 (Unified Extensible Firmware Interface,UEFI)相辅相成。
UEFI 用于取代老旧的 BIOS,而 GPT 则取代老旧的 MBR。之所以称为“GUID 分区表”,是因为驱动器上的每个分区都有一个全局唯一的标识符。
在 GPT 硬盘中,分区表的位置信息储存在 GPT 头中。出于兼容性考虑,第一个扇区同样有一个与 MBR 类似的标记,叫做受保护的主引导记录(Protected Main Boot Record,PMBR)。
PMBR 的作用是当使用不支持 GPT 的分区工具时,整个硬盘将显示为一个受保护的分区,以防止分区表及硬盘数据遭到破坏,而其中存储的内容和 MBR 一样,之后才是 GPT头。GPT 优点支持 2T 以上磁盘,如果使用 Fdisk 分区,最大只能建立 2TB 大小的分区,创建大于 2TB 的分区,需使用 parted,同时必须使用 64 位操作系统,Mac、Linux 系统都能支持 GPT 分区格式,Windows 7/8 64bit、Windows Server 2008 64bit 支持 GPT。
如图所示:
在这里插入图片描述

4、GRUB

GNU 项目的多操作系统启动程序(GRand Unified Bootloader,GRUB),可以支持多操作系统的引导,它允许用户可以在计算机内同时拥有多个操作系统,并在计算机启动时选择希望运行的操作系统。
GRUB 可用于选择操作系统分区上的不同内核,也可用于向这些内核传递启动参数。它是一个多重操作系统启动管理器。用来引导不同系统,如 Windows,Linux。Linux 常见的引导程序包括:LILO、GRUB、GRUB2,CentOS 7 Linux 默认使用 GRUB2 引导程序,引导系统启动。
GRUB2 是基于 GRUB 开发成更加安全强大的多系统引导程序,最新 Linux 发行版都是使用 GRUB2 作为引导程序。同时 GRUB2 采用了模块化设计,使得 GRUB2 核心更加精炼,使用更加灵活,同时也就不需要像 GRUB 分stage1,stage1.5,stage2 三个阶段

4、系统启动流程

对于Linux 操作系统启动流程的理解,能有助于后期在企业中更好的维护 Linux 服务器,能快速定位系统问题,进而解决问题。
在这里插入图片描述

(1) 加载 BIOS

计算机电源加电质检,首先加载基本输入输出系统(Basic Input Output System,BIOS),BIOS 中包含硬件 CPU、内存、硬盘等相关信息,包含设备启动顺序信息、硬盘信息、内存信息、时钟信息、即插即用(Plug-and-Play,PNP)特性等。加载完 BIOS 信息,计算机将根据顺序进行启动。

(2) 读取 MBR

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

(3) GRUB 引导

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

(4) 加载 Kernel

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

(5) 设定 Inittab 运行等级

内核加载完毕,会启动 Linux 操作系统第一个守护进程 init,然后通过该进程读取/etc/inittab 文件,/etc/inittab 文件的作用是设定 Linux 的运行等级,Linux 常见运行级别如下:
0:关机模式;
1:单用户模式;
2:无网络支持的多用户模式;
3:字符界面多用户模式;
4:保留,未使用模式;
5:图像界面多用户模式;
6:重新引导系统,重启模式

(6) 加载 rc.sysinit

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

(7) 加载内核模块

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

(8) 启动运行级别程序

根据之前读取的运行级别,操作系统会运行 rc0.d 到 rc6.d 中的相应的脚本程序,来完成相应的初始化工作和启动相应的服务。其中以 S 开头表示系统即将启动的程序,如果以 K开头,则代表停止该服务。S 和 K 后紧跟的数字为启动顺序编号。如图
在这里插入图片描述

(9) 读取 rc.local 文件

操作系统启动完相应服务之后,会读取执行/etc/rc.d/rc.local 文件,可以将需要开机启动的任务加入到该文件末尾,系统会逐行去执行并启动相应命令。如图
在这里插入图片描述

(10) 执行/bin/login 程序

执行/bin/login 程序,启动到系统登录界面,操作系统等待用户输入用户名和密码,即可登录到 Shell 终端,如图 3-7 所示,输入用户名、密码即可登录 Linux 操作系统,至此 Linux操作系统完整流程启动完毕。
在这里插入图片描述

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值