如何更改/转换Ubuntu MBR驱动器到GPT,并从EFI启动Ubuntu?

我最近升级了我的PC,我的新主板(华硕M5A99X EVO)使用UEFi而不是常规的MBR选项。

我有一个Ubuntu 11.10安装,当我使用我以前的硬件(MSI MS 7267),Ubuntu单独启动,Windows 7也是如此,但Windows 7使用UEFI(GPT)启动,而Ubuntu使用MBR。

我的操作系统位于不同的驱动器中,因此GRUB2不会被Windows Bootloader取代,反之亦然,因为我说两个操作系统都可以自行启动,但为了做到这一点,我必须断开一个驱动器,在这种情况下,Ubuntu驱动器为它可以防止Windows加载。

现在我的问题是,我如何更改/转换Ubuntu的驱动器,以便它不使用MBR而是使用GPT并允许Windows启动?

优选地,不重新安装整个系统或丢失任何数据。

如果我要擦除驱动器,我如何在GPT,UEFI中安装Ubuntu,无论它是什么模式?

我已经使用gdisk从MBR转换为GPT,但现在Ubuntu无法启动似乎grub只是无法启动。

我已经重新安装了操作系统,默认情况下驱动器是GPT,但仍然使用grup-pc而不是grub-efi

如何从EFI启动Ubuntu?

目录:

  1. 术语
  2. 转换
  3. 配置(+双启动)

术语

BIOS =基本输入/输出系统

(U)EFI =(统一)可扩展固件接口

MBR =主引导记录

GPT = GUID分区表

UEFI / EFI / BIOS =固件接口

MBR / GPT =计算机如何知道(每个硬盘)驱动器上的分区以及如何从它们引导。

UEFI / BIOS

固件接口是固件(设备内部的软件)和操作系统交互的方式。 它初始化硬件然后运行操作系统并确保操作系统驱动程序可以操作硬件。

BIOS一直是常用的固件接口。 UEFI是一种较新的接口,具有多种function,例如速度更快,具有GUI并能够启动网卡并获取IP地址。 UEFI取代了EFI。 (那些开发EFI的人看到其他人做了类似的事情并加入了他们,带来了EFI的想法。然后成为UEFI)。

BIOS要求引导加载程序位于磁盘的起始位置,但UEFI会为此使用分区,并可在多个引导加载程序中进行选择。

MBR / GPT + GRUB

MBR是磁盘开头的一段代码,包含引导加载程序(用于BIOS),以及分区映射和唯一磁盘标识符。

要将GRUB安装到具有MBR的磁盘上,GRUB会在MBR中放置一个小程序,以从磁盘的另一部分加载剩余的GRUB。 (这样做是因为MBR太小而不能包含所有GRUB)。 选择的空间是MBR和第一个分区之间的空间,通常存在。

GPT是如何指定分区的标准。 它确实具有“保护性”MBR,但这只是为了允许基于BIOS的计算机启动和停止只知道MBR的工具试图丢弃GPT。 它可以有

(如何处理GPT取决于它是使用BIOS(或BIOS仿真模式下的UEFI系统)还是UEFI启动。我将关注与问题相关的UEFI)。

操作系统的引导加载程序存储在名为EFI System Partiton的分区中,该分区使用FAT32格式化(通常)。 这是安装GRUB的地方。

转换

第一…

我们正在玩分区表,因此无法保证安全。 这是一个冒险的行动。 但是,该方法不应丢失数据。

其他人遇到此问题: 请勿在Apple Mac上使用。

现在…

您需要在Live CD(或安装到其他磁盘的其他Linux安装)上执行此操作。

处理GPT磁盘时,我们需要使用GPT识别程序。 ‘GPT fdisk’是一个很好的工具,我将使用它。 它可以被称为gptfdiskgdisk具体取决于分发(Ubuntu将其称为gdisk )。 Parted(和Gparted)也可以识别GPT,因此可以’安全地’与GPT磁盘一起使用。

转换你需要:

  1. 调整分区大小以适合GPT数据和EFI系统分区。
  2. 转换磁盘并添加分区
  3. 将GRUB安装到EFI系统分区。

1)调整分区大小

使用parted (命令行)或gparted (GUI)来调整第一个和最后一个分区的大小。 第一个分区应该在它之前有大约200MiB,最后一个分区应该有1MiB到2MiB(要么会)从最后开始。

2)转换磁盘

 gdisk /dev/sdx 

更改要转换的设备是/dev/sdx

它应该告诉你它将转换partiton表。

 GPT fdisk (gdisk) version 0.6.14 Partition table scan: MBR: MBR only BSD: not present APM: not present GPT: not present *************************************************************** Found invalid GPT and valid MBR; converting MBR to GPT format. THIS OPERATION IS POTENTIALLY DESTRUCTIVE! Exit by typing 'q' if you don't want to convert your MBR partitions to GPT format! *************************************************************** Command (? for help): 

现在添加一个新分区,使其类型为’EFI system’。 它应该在开头找到可用空间(我建议使用一些低扇区数字,如34)并自动使用所有可用空间。 这些示例使用4GB USB闪存驱动器,其上已有1个分区,如上所述resize。

 Command (? for help): n Partition number (2-128, default 2): 2 First sector (34-7831518, default = 34) or {+-}size{KMGTP}: Information: Moved requested sector from 34 to 2048 in order to align on 2048-sector boundaries. Use 'l' on the experts' menu to adjust alignment Last sector (2048-421887, default = 421887) or {+-}size{KMGTP}: Current type is 'Linux/Windows data' Hex code or GUID (L to show codes, Enter = 0700): L 0700 Linux/Windows data 0c01 Microsoft reserved 2700 Windows RE 4200 Windows LDM data 4201 Windows LDM metadata 7501 IBM GPFS 7f00 ChromeOS kernel 7f01 ChromeOS root 7f02 ChromeOS reserved 8200 Linux swap 8301 Linux reserved 8e00 Linux LVM a500 FreeBSD disklabel a501 FreeBSD boot a502 FreeBSD swap a503 FreeBSD UFS a504 FreeBSD ZFS a505 FreeBSD Vinum/RAID a800 Apple UFS a901 NetBSD swap a902 NetBSD FFS a903 NetBSD LFS a904 NetBSD concatenated a905 NetBSD encrypted a906 NetBSD RAID ab00 Apple boot af00 Apple HFS/HFS+ af01 Apple RAID af02 Apple RAID offline af03 Apple label af04 AppleTV recovery be00 Solaris boot bf00 Solaris root bf01 Solaris /usr & Mac Z bf02 Solaris swap bf03 Solaris backup bf04 Solaris /var bf05 Solaris /home bf06 Solaris alternate se bf07 Solaris Reserved 1 bf08 Solaris Reserved 2 bf09 Solaris Reserved 3 bf0a Solaris Reserved 4 bf0b Solaris Reserved 5 c001 HP-UX data c002 HP-UX service ef00 EFI System ef01 MBR partition scheme ef02 BIOS boot partition fd00 Linux RAID Hex code or GUID (L to show codes, Enter = 0700): ef00 Changed type of partition to 'EFI System' 

您现在应该拥有EFI分区。

 Command (? for help): p Disk /dev/sdd: 7831552 sectors, 3.7 GiB Logical sector size: 512 bytes Disk identifier (GUID): 669247F2-37F7-4797-98F9-9CE56F7EA8C8 Partition table holds up to 128 entries First usable sector is 34, last usable sector is 7831518 Partitions will be aligned on 2048-sector boundaries Total free space is 4029 sectors (2.0 MiB) Number Start (sector) End (sector) Size Code Name 1 421888 7829503 3.5 GiB 0700 Linux/Windows data 2 2048 421887 205.0 MiB EF00 EFI System 

然后退出gdisk

 Command (? for help): w Final checks complete. About to write GPT data. THIS WILL OVERWRITE EXISTING PARTITIONS!! Do you want to proceed, possibly destroying your data? (Y/N): y OK; writing new GUID partition table (GPT). The operation has completed successfully. 

现在使用Gparted(或命令行mkfs.vfat )将分区格式化为FAT32。

3)安装GRUB

这与前一部分的保证较少,因为我自己没有尝试过。

我不确定这一步,所以我猜是使用RAOF的说明 :

切换到你想要的grub-efi

  1. 找到您的EFI分区; 将它挂载在/ boot / efi中。 将其添加到/ etc /fstab¹
  2. 安装grub-efi包
  3. 将BIOS启动优先级从UEFI和Legacy切换到UEFI(或类似选项)

您应该确定要安装的grub-efi版本

 ioreg -l -p IODeviceTree | grep firmware-abi 

如果说EFI32安装grub-efi-ia32软件包,如果说EFI64安装了grub-efi-amd64软件包。 您可以使用安装包

 sudo apt-get install  

这可能仅在您以EFI模式启动时才有效。

如果它不起作用,您可以在安装grub-efi尝试这些分步说明(在“(U)EFI系统中安装GRUB2”)。

配置(+双启动)

如果RAOK的说明有效,您应该能够将以下行添加到/etc/grub.d/40_custom

 menuentry "Windows 7" { set root='(hd0,gpt1)' chainloader /EFI/microsoft/bootmgfw.efi } 

它假定Windows被GRUB识别为hd0 。 可能需要将其更改为hd1才能工作。

现在跑

 update-grub 

更新配置文件。

参考和进一步阅读

我用过几个来源。

  • 罗德史密斯的“ GPT fdisk教程 ”。 好的更多信息。
  • 适用于UEFI , BIOS , MBR和GPT的维基百科页面。
  • Ubuntu的UEFI启动wiki页面 。 如果你遇到困难,还有更多的方法。
  • UEFI自己关于页面 。

这个答案是不完整的; 我没有测试任何这个。 它不太可能吃掉你的任何数据,但你已被警告过了!

我猜这里发生的是你的BIOS优先从传统的MBR启动,所以可怜的老UEFI Windows 7被忽视了。

关于UEFI的一个好处是你不再需要担心Windows覆盖GRUB; 它们应该在EFI分区上很好地共存。 因此,一种选择是切换到grub-efi注意:我不确定grub-efi是否理解MSDOS风格的分区; 我认为确实如此。 如果没有,则无法启动,您需要LiveCD才能恢复。 事实上,无论如何都要有一个LiveCD方便!

切换到你想要的grub-efi

  1. 找到您的EFI分区; 将它挂载在/boot/efi 。 将其添加到/etc/fstab
  2. 安装grub-efi
  3. 将BIOS启动优先级从UEFI and Legacy切换到UEFI only (或类似选项)

应该让你使用UEFI启动Ubuntu安装。 如果没有,启动您可信赖的LiveCD(或Ubuntu Alternate安装CD – “修复损坏的系统”选项就是您所追求的☺),chroot进入您的系统,并再次安装grub-pc


¹:此步骤的更多细节:您需要找到Linux内核调用EFI系统分区的内容。 这将是/dev/sda2/dev/sdb3等等。 然后,您需要创建/boot/efi目录,并在/etc/fstab添加一行。 如果您的EFI分区是/dev/sdb3 ,那么您将添加以下行:

 /dev/sdb3 /boot/efi vfat defaults 0 1 

运行sudo mount /boot/efi您应该发现/boot/efi包含一个EFI目录,其中包含Windows 7的子目录。


²:由于您有多个硬盘驱动器,因此最好找出分区的UUID,因为在添加/删除硬盘时这将是稳定的,而/dev/sda2名称不保证不会改变。 但是,在完成其他所有操作后,可以执行此操作。

您可以通过查看/dev/disk/by-uuid找到UUID。 例如,我得到:

 $ ls /dev/disk/by-uuid -lah total 0 drwxr-xr-x 2 root root 100 Dec 5 09:12 . drwxr-xr-x 6 root root 120 Dec 5 09:12 .. lrwxrwxrwx 1 root root 10 Dec 5 09:12 27fae347-4c7f-45cb-92d6-5f3d410599a1 -> ../../sda3 lrwxrwxrwx 1 root root 10 Dec 5 09:12 4405-64C8 -> ../../sda1 lrwxrwxrwx 1 root root 10 Dec 5 09:12 5243e250-8da5-4fea-aa63-61466022661d -> ../../dm-0 

就我而言,我知道/dev/sda1是我的EFI系统分区,所以我有

 UUID=4405-64C8 /boot/efi vfat defaults 0 1 

在我的/etc/fstab

我的操作系统位于不同的驱动器中,因此GRUB2不会被Windows Bootloader取代,反之亦然

这是理想的,因此您可能在分区表中至少有一个主分区空闲。

现在我的问题是,我如何更改/转换Ubuntu的驱动器,以便它不使用MBR而是使用GPT并允许Windows启动?

您不必将MBR转换为GPT以进行UEFI引导,只需创建主FAT分区,安装grub-efi-amd64-bin软件包并按照添加ESP到具有MBR的现有安装中的说明进行操作当前版本的Ubuntu。

为了补充Portablejim的答案 (这真的帮助我从MBR转换为GPT,谢谢!),你可以使用Boot-Repair来重新安装grub。 在我未能完成第3步之后,它就像修饰我的启动一样,并且当Windows 10的安装使得linux启动选项消失时再一次。