系统引导过程概述以MBR,PBR,BIOS,boot loader各个名词解析

2023-11-25 04:50

本文主要是介绍系统引导过程概述以MBR,PBR,BIOS,boot loader各个名词解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前情:

因为个人的需要,要在mac上安装三个系统,mac+win10+ubuntu。

mac上安装多系统实现多引导的情况比一般电脑的复杂,其中的理论知识会牵涉到各种各样的名词,什么GUID、GPT、EFI 之类的……在安装以前,需要复习一下基本的计算机知识,于是准备写两篇博文,上篇介绍基本的磁盘分区,MBR、PBR、BIOS以及系统引导的过程,下篇介绍mac下关于GUID、GPT、EFI,以及如何实现三系统。

这篇文章是上篇:系统引导过程概述以&MBR,PBR,BIOS各个名词解析

知识补充:

1、磁盘的组成:

磁盘的组成(主要有盘片,机械手臂,磁头与主轴马达所组成),而数据的写入其实在盘片上面。盘片又可以细分出扇区(sector)、柱面(cylinder)两种单位,其中扇区每个为512bytes。

整块磁盘的第一个扇区特别重要,因为它记录了整块磁盘的重要信息,分别是:

1).主引导程序即主引导记录(MBR,Master Boot Record)(占446个字节)
放置引导加载程序的地方。其中引导加载程序(boot loader)除了可以安装在MBR,还可以安装在PBR(下面解释)
2).磁盘分区表项(DPT,Disk Partition Table)  (占64个字节)
每条分区记录占16字节,因此最多容纳4个分区记录,它们有主分区(primary)和扩展分区(extend)构成。其中扩展分区最多只能有一条。但这并代表整个磁盘只能分四个区,当分区多余四个的时候,前三个为主分区,剩下的分区由扩展分区继续分区出来,也叫逻辑分区(logical)。记住能够格式化的只要主分区和逻辑分区,扩展分区不能格式化。


3).结束标志(占2个字节)
其值为AA55,存储时低位在前,高位在后,即看上去是55AA(十六进制)。

通常,我们将包含MBR引导代码的扇区称为主引导扇区。因这一扇区中,引导代码占有绝大部分的空间,故而将习惯将该扇区称为MBR扇区(简称MBR),同样也是512个字节大小。


2、磁盘的分区

在每个分区里,又有两个重要概念:

1)PBR,即 Partition Boot Record ,位置在每个磁盘分区的开始部分,占用扇区不定,所在的扇区又叫做当前分区的(boot sector)。这个扇区一般保存着操作系统引导程序(boot loader)的所在位置。下图的红色部分。那既然MBR里已经有boot loader了,为什么又要设一个PBR里再保存boot loader呢?原因是不同操作系统文件格式不一样,每种操作系统都有自己的boot loader,用自己的boot loader才能载入自己的内核文件。因此,每个操作系统默认是会安装一套boot loader到自己的分区的PBR中,且可以选择是否也安装到MBR上。如果选择安装到MBR的话,理论上在MBR和PBR里都有一份boot loader程序。
2)文件系统,File System ,操作系统对磁盘的所有操作都需要经过文件系统,删除文件指的是在文件系统里删除文件的索引条目,创建文件就是在在文件系统里添加索引条目并将具体数据写入磁盘。常见的文件系统格式有: FAT exFAT NTFS HFS+ 。文件系统位置一般在PBR之后。下图黄色部分。


3、BIOS与CMOS

CMOS是记录各项硬件参数且嵌入主板上的存储器,在系统启动时需要读取里面的设置。BIOS则是一个写入到主板上的一个韧体(即写入到硬件上的一个软件程序),这个BIOS就是在开机的时候计算机系统会主动执行的第一个程序。

4、boot loader

上面提了那么多次的boot loader,那么boot loader主要完成什么工作呢?而且系统的MBR只有一份,要怎么执行boot sector里面的loader呢?boot loader的主要功能如下:

1)提供菜单:用户可以选择不同的启动选项,这也是多重引导的重要功能!选择不同的内核来启动。

2)加载内核文件:直接指向可启动的程序区段来开始操作系统。

3)转交其他loader:将引导装载功能转交给其他loader负责。可以加载其他boot sector内的boot loader。

常见的boot loader有linux下的grub,windows的bootmgr。

系统引导过程

1、传统BIOS引导过程:

计算机器开机后,固化在 ROM 里的 BIOS 就会被加载到内存运行,BIOS 自检完毕以后加载 COMS 的参数,通过 COMS 的参数, BIOS 程序加载启动磁盘的 MBR 到内存里运行。通过运行 MBR 的代码,记录在 MBR 分区表中,标记为活动分区的磁盘分区 PBR 被加载到内存。与 MBR 类似,PBR 在运行后加载操作系统的引导程序到内存运行,例如 Windows 的 bootmgr 。当引导程序运行后,操作系统内核就被加载运行,完成从 BIOS 程序中接手的引导流程。

2、linux启动流程一览:

这里深入地补充一下linux的启动具体流程:
    (1)加载 BIOS 的硬件资讯与进行自我测试,并依据配置取得第一个可启动的装置;
    (2)读取并运行第一个启动装置内 MBR 的 boot Loader (亦即是 grub, spfdisk 等程序);
    (3)依据 boot loader 的配置加载 Kernel ,Kernel 会开始侦测硬件与加载驱动程序;
    (4)在硬件驱动成功后,Kernel 会主动呼叫 init 程序,而 init 会取得 run-level 资讯;
    (5)init 运行 /etc/rc.d/rc.sysinit 文件来准备软件运行的作业环境 (如网络、时区等);
    (6)init 运行 run-level 的各个服务之启动 (script 方式);
    (7)init 运行 /etc/rc.d/rc.local 文件;
    (8)init 运行终端机模拟程序 mingetty 来启动 login 程序,最后就等待使用者登陆啦;

3、windows和linux双系统引导:

由于boot loader可以将控制权转交其他lodaer,将引导装载功能转给其他loader负责,可以实现多重引导。

像windows和linux在安装的时候,都会主动将MBR和自己所在分区的PBR里。不过windows的loader默认不具有控制权转交功能,因此不能使用windows的loader来加载linux的loader。如果先安装linux再安装windows,windows覆盖了MBR中linux的boot loader,且不给linux的boot loader做转交,就不能实现双引导启动了。这也就是为什么要先安装windows,再安装linux了。

                       


参考:

《鸟哥的linux私房菜》基础篇

【Mac技术组】Mac 系统引导过程概述 & BootCamp 的秘密

这篇关于系统引导过程概述以MBR,PBR,BIOS,boot loader各个名词解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/423146

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、