BIOS, MBR, UEFI和GPT到底是什么?

你是否在每次安装操作系统的时候,都搞不清BIOS,MBR,UEFI和GPT这些名词之间的关系?今天这篇文章绝对可以给你带来一个更清晰的理解。

首先我们来看看电脑是怎么启动的。我们知道,当电脑被接上电源以后,它需要读取储存在硬盘上的操作系统启动代码来启动操作系统。但是电脑要怎么找到这些代码储存在什么地方呢?传统上人们把这个任务交给BIOSBIOS是储存在主板上的固件(Firmware),实际上就是一个在电脑通电的时候会被自动运行的程序。由于早期技术的限制,BIOS只能运行一些非常简单的指令,所以如果要用它来从硬盘文件系统中直接定位并读取相关的操作系统启动代码不太现实。为了解决这个问题,人们把用来启动操作系统的指令放在硬盘上的一个固定的,容易找到的位置,那么BIOS就不需要在硬盘里面搜索,而是只需要直接从那个特定地方读取指令并运行就可以了。这就是MBRMaster Boot Record)格式的来源。下图是MBR格式硬盘的内部布局(来源):

MBR硬盘内部布局.png

我们可以看到,使用MBR格式的硬盘把硬盘分区的信息还有一个启动小程序(Master Boot Code)放在硬盘的第一个扇区(sector)(图中蓝色部分),当BIOS启动的时候就从这一个扇区读取并运行启动小程序。由于扇区大小的限制,往往MBR中的启动小程序还没有能力直接启动操作系统,它还需要再加载一段耳机启动程序来达到最终启动操作系统的目的。根据操作系统的不同,这个过程也略有不一样,例如对于Windows系统,MBR中的启动小程序会找到当前的活跃分区(active partition),然后读取位于活跃分区第一个扇区的二级启动程序来达成Windows的启动。而对于Linux系统,MBR中的小程序会启动储存于MBR和第一分区中间的二级启动程序,而这个启动程序会找到GRUB2程序位置,启动GRUB2,从而最终达到启动Linux的目的。

MBR硬盘的优点是原理简单,而且能够兼容只支持BIOS的老主板。但随着时间的发展,MBR也暴露出越来越多的问题。受制于扇区的大小,MBR最多只能支持4个主分区,而且最大只能支持2TB的容量。为此,人们开发了一种新的硬盘格式:GPTGUID Partition Table)。与MBR不同的是,在GPT中,分区信息不再被储存在第一个扇区当中。没有了这个限制,GPT能够有更多的空间储存分区的信息,使得分区数量最多能达128个。而且所支持硬盘的最大容量也提升到了9.4ZB。下图是GPT硬盘的内在布局:

GPT硬盘内在布局.png

可以看到的是,现在分区表所占空间是33个扇区(图中绿色部分),而且在硬盘最后还有一个分区表的备份,对防止硬盘数据损坏多了一重保障。值得注意的是图中灰色部分有一个叫Protective MBR的区域。GPT专门腾出这个区域来防止一些程序把该硬盘当作MBR硬盘写入信息从而破坏分区表。

同时人们也开始觉得,像MBR一样把启动程序挤在第一个扇区实在太有局限性了。所以在系统启动上GPT也采用了新的方式:GPT中有一个系统分区(system partition),该硬盘上所有操作系统的启动程序都像平常的可执行程序一样放在这个系统分区中。启动的时候固件只需要找到这个系统分区,列出里面的程序让用户选择哪个操作系统来运行就可以了。

这个新的硬盘格式对主板的固件提出了更高的要求,例如这个固件需要能够在GPT中找到并读取分区表,这个固件还需要明白文件系统(File System)来读取启动程序。很明显,传统BIOS并不能胜任这项工作。我们需要一个新的固件标准,UEFI正好能够满足这样的要求。相比起BIOS,UEFI能够执行更加复杂的指令,同时还能提供对用户更加友好的界面,将会在将来逐渐取代BIOS。为了维持兼容性,UEFI往往会带有Legacy模式来兼容MBR格式的硬盘。

在了解了MBRGPT的不同以后,我们能够更好的理解有时候安装多系统时遇到的问题。例如当你在MBR硬盘中先安装了Windows,然后安装Linux作为双系统的时候,Linux安装程序实际上会替换掉原来在MBR中的启动小程序,使它指向新的GRUB2启动程序。但是由于原来的启动小程序被替换了,当你卸载Linux以后,GRUB2也随之被卸载了,你的Windows也不能够启动了。这个时候你必须要使用你的Windows启动盘来先修复MBR里的小程序,从而能够再启动Windows。同样情形如果发生在一个GPT硬盘上,卸载Linux只是意味着删除系统分区中其中一个启动程序而已。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,542评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,596评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,021评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,682评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,792评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,985评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,107评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,845评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,299评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,612评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,747评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,441评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,072评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,828评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,069评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,545评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,658评论 2 350

推荐阅读更多精彩内容

  • BIOS和CMOS 名词解释 BIOS "Basic Input Output System"BIOS是个人电脑启...
    一颗老鼠屎阅读 2,142评论 0 1
  • 从Intel 6系列主板之后,就开始提供UEFI BIOS支持,正式支持GPT硬盘分区表,一举取代了此前的MBR分...
    DecadeHeart阅读 1,695评论 0 1
  • tags: Linux OS GRUB 硬盘分区 背景 2016年双十一入手了一块500G的 SSD(Solid ...
    CntChen阅读 11,082评论 2 20
  • 理论部分 镜像 一、镜像的百科定义 1、维基百科 ISO映像是一种光盘的存档文件(英语:archive file)...
    幻影翔阅读 1,910评论 4 3
  • 转载声明:本文虽然不是本人100%原创,但也是辛辛苦苦整理的,可以转载,但请注明出处 这篇文章是关于折腾Windo...
    SOMCENT阅读 8,009评论 3 37