Wie kann ich ein Ubuntu-MBR-Laufwerk in ein GPT ändern / konvertieren und Ubuntu über EFI booten lassen?

65

Ich habe kürzlich meinen PC aktualisiert. Mein neues Motherboard (ASUS M5A99X EVO) verwendet UEFi anstelle der normalen MBR-Option.

Ich habe eine Ubuntu 11.10-Installation, die ich durchgeführt habe, als ich meine vorherige Hardware (MSI MS 7267) hatte. Ubuntu allein bootet gut, und Windows 7 auch. Windows 7 verwendet jedoch UEFI (GPT) -Start, während Ubuntu MBR verwendet.

Ich habe meine Betriebssysteme in getrennten Laufwerken, so dass GRUB2 nicht durch den Windows-Bootloader und umgekehrt ersetzt wird, da ich sagte, dass beide Betriebssysteme gut alleine booten, aber um dies zu tun, muss ich in diesem Fall ein Laufwerk vom Ubuntu-Laufwerk trennen Es verhindert, dass Windows geladen wird.

Nun ist meine Frage: Wie kann ich Ubuntus Laufwerk so ändern / konvertieren, dass anstelle von MBR GPT verwendet wird und Windows gebootet werden kann?

Am besten ohne Neuinstallation des gesamten Systems oder Datenverlust.

Und wenn ich das Laufwerk löschen würde, wie kann ich Ubuntu in GPT, UEFI, installieren, egal in welchem ​​Modus?

Ich habe gdisk verwendet, um von MBR nach GPT zu konvertieren, aber jetzt kann Ubuntu nicht mehr booten.

Ich habe das Betriebssystem neu installiert, und das Laufwerk ist jetzt standardmäßig GPT, wird jedoch grup-pcweiterhin anstelle von verwendet grub-efi.

Wie kann ich Ubuntu von EFI booten lassen?

Uri Herrera
quelle
Hoffentlich hilft Ihnen das rodbooks.com/gdisk/booting.html .
One Zero

Antworten:

113

Inhaltsverzeichnis:

  1. Terminologie
  2. Konvertieren
  3. Konfigurieren (+ Dual Boot)

Terminologie

BIOS = Basic Input / Output System

(U) EFI = (Unified) Extensible Firmware Interface

MBR = Master Boot Record

GPT = GUID-Partitionstabelle

UEFI / EFI / BIOS = Firmware-Schnittstelle

MBR / GPT = Wie der Computer (pro Festplatte) weiß, welche Partitionen sich auf dem Laufwerk befinden und wie man von ihnen bootet.

UEFI / BIOS

Eine Firmware-Schnittstelle ist die Art und Weise, wie die Firmware (die Software in den Geräten) und das Betriebssystem interagieren. Es initialisiert die Hardware, führt dann das Betriebssystem aus und stellt sicher, dass die Betriebssystemtreiber die Hardware bedienen können.

Das BIOS war die übliche Firmware-Schnittstelle, die verwendet wurde. Die UEFI ist eine neuere Schnittstelle, die verschiedene Funktionen bietet, z. B. eine schnellere Oberfläche, eine grafische Benutzeroberfläche und die Möglichkeit, die Netzwerkkarte zu starten und eine IP-Adresse abzurufen. UEFI ersetzt EFI. (Diejenigen, die EFI entwickelten, sahen, dass es andere gab, die etwas Ähnliches taten, und schlossen sich ihnen an und brachten die Ideen von EFI mit. Dies wurde dann UEFI).

Ein BIOS setzt voraus, dass sich der Bootloader am Anfang der Festplatte befindet. Eine UEFI verwendet jedoch eine Partition für diese und kann aus mehreren Bootloadern auswählen, die verwendet werden sollen.

MBR / GPT + GRUB

Der MBR ist ein Codeabschnitt am Anfang der Festplatte, der einen Bootloader (für das BIOS) sowie die Partitionszuordnung und eine eindeutige Festplattenkennung enthält.

Um GRUB auf einem Datenträger mit einem MBR zu installieren, fügt GRUB ein kleines Programm in den MBR ein, um den Rest von GRUB von einem anderen Teil des Datenträgers zu laden. (Dies geschieht, weil der MBR zu klein ist, um alle GRUBs aufzunehmen.) Der ausgewählte Speicherplatz ist der Speicherplatz zwischen dem MBR und der ersten Partition, der normalerweise vorhanden ist.

GPT ist ein Standard für die Angabe der Partitionen. Es hat zwar einen "schützenden" MBR, dies dient jedoch nur dazu, BIOS-basierten Computern das Starten und Stoppen von Tools zu ermöglichen, die nur über MBR Bescheid wissen, wenn sie versuchen, GPT in den Papierkorb zu werfen. Es kann haben

(Wie mit GPT umgegangen wird, hängt davon ab, ob das System über ein BIOS (oder ein UEFI-System im BIOS-Emulationsmodus) oder UEFI gebootet wird. Ich werde mich auf UEFI konzentrieren, da es sich auf die Frage bezieht.)

Bootloader für Betriebssysteme werden in einer Partition namens EFI System Partiton gespeichert, die (normalerweise) mit FAT32 formatiert ist. Hier wird GRUB installiert.

Konvertieren

Zuerst...

Wir spielen mit dem Raumteilertisch herum, daher ist eine garantierte Sicherheit nicht möglich. Es ist eine riskante Operation. Die Methode sollte jedoch keine Daten verlieren.

Andere, die darauf stoßen: Nicht auf Apple Macs verwenden.

Jetzt...

Sie müssen dies auf einer Live-CD tun (oder einer anderen Linux-Installation, die auf einer anderen Festplatte installiert ist).

Beim Umgang mit GPT-Datenträgern müssen wir ein GPT-fähiges Programm verwenden. 'GPT fdisk' ist ein gutes Werkzeug und was ich verwenden werde. Es kann aufgerufen werden gptfdiskoder gdiskabhängig von der Distribution (Ubuntu nennt es gdisk). Parted (und Gparted) sind auch GPT-fähig und können daher mit GPT-Datenträgern "sicher" verwendet werden.

Um zu konvertieren, müssen Sie:

  1. Passen Sie die Partitionsgröße an die GPT-Daten und die EFI-Systempartition an.
  2. Konvertieren Sie die Festplatte und fügen Sie Partitionen hinzu
  3. Installieren Sie GRUB auf der EFI-Systempartition.

1) Partitionsgröße ändern

Verwenden Sie parted(Befehlszeile) oder gparted(GUI), um die Größe der ersten und letzten Partition zu ändern. Die erste Partition sollte ungefähr 200 MB haben, und die letzte Partition sollte 1 MB bis 2 MB haben (beides reicht).

2) Konvertieren Sie die Festplatte

Lauf

gdisk /dev/sdx

Ändern Sie das Gerät, das Sie konvertieren möchten /dev/sdx.

Es sollte Ihnen mitteilen, dass die Partitionstabelle konvertiert wird.

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): 

Fügen Sie nun eine neue Partition vom Typ "EFI-System" hinzu. Es sollte den freien Speicherplatz am Anfang finden (ich schlage eine niedrige Sektornummer wie 34 vor) und automatisch den gesamten freien Speicherplatz verwenden. In den Beispielen wird ein USB-Flash-Laufwerk mit 4 GB verwendet, auf dem sich bereits eine Partition befindet. Die Größe wurde wie oben angegeben geändert.

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'

Sie sollten jetzt die EFI-Partition haben.

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

Dann geh 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.

Verwenden Sie jetzt Gparted (oder die Befehlszeile mkfs.vfat), um die Partition als FAT32 zu formatieren.

3) Installieren Sie GRUB

Das kommt mit weniger Sicherheit, dass ich den vorherigen Teil nicht selbst ausprobiert habe.

Ich bin mir bei diesem Schritt nicht sicher, daher rate ich, die Anweisungen von RAOF zu befolgen :

Um zu grub-efi zu wechseln, möchten Sie

  1. Suchen Sie Ihre EFI-Partition. mounten Sie es in / boot / efi. Fügen Sie dies zu / etc / fstab¹ hinzu
  2. Installieren Sie das Paket grub-efi
  3. Wechseln Sie die BIOS-Startpriorität von UEFI und Legacy nur zu UEFI (oder einer ähnlichen Option).

Sie sollten herausfinden, mit welcher Version von grub-efi Sie installieren möchten

ioreg -l -p IODeviceTree | grep firmware-abi

Wenn es heißt, EFI32installieren Sie das grub-efi-ia32Paket, wenn es heißt, EFI64 installieren Sie das grub-efi-amd64Paket. Sie können die Pakete mit installieren

sudo apt-get install <package name>

Dies funktioniert wahrscheinlich nur, wenn Sie im EFI-Modus gebootet haben.

Wenn dies nicht funktioniert, können Sie diese schrittweisen Anweisungen (unter "Installieren von GRUB2 in (U) EFI-Systemen") nach der grub-efiInstallation ausführen.

Konfigurieren (+ Dual Boot)

Wenn die Anweisungen von RAOK funktionieren, sollten Sie in der Lage sein, die folgende Zeile hinzuzufügen /etc/grub.d/40_custom

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

Es wird davon ausgegangen, dass Windows hd0von GRUB erkannt wird. Es muss möglicherweise geändert werden, hd1um zu arbeiten.

Jetzt lauf

update-grub

um die Konfigurationsdatei zu aktualisieren.

Referenzen und weiterführende Literatur

Ich habe mehrere Quellen verwendet.

Portablejim
quelle
WOah, danke! .. aber ich bin immer noch in der Installation von grub-efi auf dem Laufwerk stecken geblieben, ich habe das Betriebssystem neu installiert und das Laufwerk GPT gemacht, aber es ist immer noch mit grub-pc nicht grub-efi.
Uri Herrera
Wenn Sie die Option haben (da ich keine UEFI-Geräte besitze, die mir schwer helfen können), müssen Sie die Live-CD im UEFI-Modus und nicht im BIOS / MBR-Modus starten.
Portablejim
Wie wäre es grub-pc, grub-efiwenn Sie die Live-CD entfernen und installieren (bevor Sie sie installieren?)?
Portablejim
1
Wow, das hat einwandfrei funktioniert, danke! Ich habe gerade eine parallele Installation von Fedora 25 und Windows 10 von MBR + BIOS auf GPT + UEFI migriert, ohne etwas neu zu installieren. Ich habe die Schritte 1 und 2 von einem Fedora 25 Live-USB-Stick ausgeführt, der mit UEFI gebootet wurde. In Schritt 3 habe ich chroot verwendet, um vom Live-System aus auf mein vorhandenes System zuzugreifen, wie unter wiki.ubuntuusers.de/GRUB_2/Reparatur/#chroot-Methode beschrieben . Ich habe grub2 deinstalliert, grub2-efi und grub2-efi-Module installiert und shim explizit neu installiert (ohne die Neuinstallation von shim würde das Grub-Menü nicht erscheinen). Endlich ...
Philipp Hartwig
2
Für die Installation von GRUB habe ich gerade einen Live-USB-Stick gebootet und Boot-Repair verwendet. askubuntu.com/questions/226061/… Danke für diesen Beitrag!
Jbrock
9

Diese Antwort ist unvollständig; Ich habe nichts davon getestet. Es ist unwahrscheinlich, dass Daten von Ihnen abgerufen werden, aber Sie wurden gewarnt!

Was ich vermute, passiert hier, ist, dass Ihr BIOS vorzugsweise von einem alten MBR bootet, so dass schlechtes altes UEFI Windows 7 übersehen wird.

Eines der schönen Dinge an UEFI ist, dass Sie sich keine Sorgen mehr machen müssen, dass Windows GRUB überschreibt. Sie sollten beide gut auf der EFI-Partition koexistieren. Eine Möglichkeit wäre daher, zu wechseln grub-efi. Hinweis: Ich bin nicht sicher, ob ich grub-efiPartitionen im MSDOS-Stil verstehe. Ich denke schon . Wenn dies nicht der Fall ist, schlägt der Start fehl und Sie benötigen eine Live-CD, um wiederherzustellen. In der Tat, haben Sie eine Live-CD ohnehin griffbereit!

Zu wechseln, zu dem grub-efiSie wechseln möchten

  1. Suchen Sie Ihre EFI-Partition. montieren Sie es in /boot/efi. Fügen Sie dies zu /etc/fstab¹ hinzu
  2. Installieren Sie das grub-efiPaket
  3. Schalten Sie die BIOS-Startpriorität von UEFI and Legacyauf UEFI only(oder eine ähnliche Option).

Das sollte dich mit einer UEFI-bootenden Ubuntu-Installation lassen. Wenn dies nicht der Fall ist, starten Sie Ihre vertrauenswürdige Live-CD (oder Ubuntu Alternate-Installations-CD - die Option „Fix a broken system“ ist Ihre Aufgabe ☺), chrooten Sie in Ihr System und installieren Sie es grub-pcerneut.


¹: Weitere Informationen zu diesem Schritt: Sie müssen herausfinden, wie der Linux-Kernel Ihre EFI-Systempartition nennt. Das wird so etwas wie /dev/sda2, /dev/sdb3oder such². Sie müssen dann das /boot/efiVerzeichnis erstellen und eine Zeile hinzufügen /etc/fstab. Wenn Ihre EFI-Partition ist /dev/sdb3, würden Sie die folgende Zeile hinzufügen:

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

Sobald Sie ausgeführt haben sudo mount /boot/efi, sollten Sie feststellen, dass /boot/efiein EFIVerzeichnis mit einem Unterverzeichnis für Windows 7 enthält.


²: Da Sie über mehrere Festplatten verfügen, ist es möglicherweise eine gute Idee, die UUID der Partition zu ermitteln, da diese beim Hinzufügen / Entfernen von Festplatten stabil bleibt, während sich der /dev/sda2Name nicht garantiert nicht ändert. Dies kann jedoch erfolgen, nachdem Sie alle anderen Einstellungen vorgenommen haben.

Sie finden die UUID, indem Sie nachsehen /dev/disk/by-uuid. Zum Beispiel bekomme ich:

$ 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

Ich weiß, dass /dev/sda1es sich bei meiner EFI-Systempartition handelt

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

in meinem /etc/fstab.

RAOF
quelle
Wenn Windows 7 von EFI bootet, hat es seinen Bootloader in der EFI-Partition abgelegt - Sie müssen also einen haben. Dies wird nicht sichtbar überall in dem Standard - Ubuntu - Dateisystem sein. Sie müssen es mit so etwas wie dem Disk utilityProgramm finden. Solange Sie Ihre EFI-Partition grub-efinicht gefunden und gemountet haben , funktioniert sie nicht. Sie muss ihren Bootloader in die EFI-Systempartition stecken.
RAOF
Ich kann immer noch nicht in Ubuntu booten, habe die Zeilen mit einer Live-CD zu fstab hinzugefügt und auch das efi-Verzeichnis in / boot erstellt, aber es scheint keinen Effekt zu haben.
Uri Herrera
Nachdem Sie die EFI-Partition aktiviert haben, müssen Sie GRUB ausführen sudo grub-installund sudo update-grubinstallieren und auf der EFI-Partition einrichten. Dies müssen Sie nach dem Chrooten in Ihre Installation tun (da Sie Informationen zur Installation auf Ihrer Festplatte benötigen). Wenn Sie dabei Hilfe benötigen, kann ich der Antwort Details hinzufügen.
RAOF
Ja, bitte füge hinzu, wie man chroot in meine Installation einfügt und grub neu installiert.
Uri Herrera
Ich habe die Anweisungen hier befolgt, aber ich hatte ein Problem mit der neuen EFI-Partition. Beim Versuch, eine Windows 10-Vorschau zu installieren, gab das Installationsprogramm den folgenden Fehler aus: "Windows hat festgestellt, dass die EFI-Systempartition als NTFS formatiert wurde. Formatieren Sie die EFI-Systempartition als FAT32 und starten Sie die Installation neu." Das Problem konnte mithilfe von behoben werden das mit dem Windows-Installationsprogramm gelieferte Diskpart-Tool, indem die erste EFI-Partition gelöscht und eine weitere mit erstellt wird create partition efi. Informationen zu diskpart finden Sie unter technet.microsoft.com/en-us/library/cc766465%28WS.10%29.aspx
Pathogen,
2

Ich habe meine Betriebssysteme auf separaten Laufwerken, sodass GRUB2 nicht durch den Windows-Bootloader und umgekehrt ersetzt wird

Idealerweise ist mindestens eine primäre Partition in der Partitionstabelle frei.

Nun ist meine Frage: Wie kann ich Ubuntus Laufwerk so ändern / konvertieren, dass anstelle von MBR GPT verwendet wird und Windows gebootet werden kann?

Sie müssen MBR nicht in GPT konvertieren, um UEFI zu booten. Erstellen Sie einfach eine primäre FAT-Partition, installieren Sie das grub-efi-amd64-binPaket und folgen Sie den Anweisungen unter Hinzufügen eines ESP zu einer vorhandenen Installation mit MBR, die mit aktuellen Ubuntu-Versionen funktionieren sollte.

LiveWireBT
quelle
1
Antwort unterbewertet. Windows erfordert hartnäckig einen GPT + UEFI- oder MBR + BIOS-Start, aber Linux ermöglicht Mix-and-Match und Grub kann eine andere Festplatte hintereinander laden oder Windows 7 bootmgr direkt starten.
Tim G
@timg Dies mag nachträglich zutreffen, aber wenn Sie Windows 10 von Grund auf neu einrichten, lässt das Installationsprogramm Sie leider nicht ohne GPT-Volume fortfahren, wenn Sie EFI gestartet haben.
Merk
@Merk Oh, ich benutze das Windows Installer eine andere Art und Weise: Umschalt-F10 gibt Ihnen eine Befehlszeile und Sie können diskpart, dism /apply-imagedann bcdboot(weitere Optionen auf diese beiden natürlich) , um es mbr make install oder gpt unabhängig davon , wie Sie gestartet.
Tim G
1

Als Ergänzung zu Portablejims Antwort (die mir beim Konvertieren von MBR zu GPT sehr geholfen hat, danke!) Können Sie Boot-Repair verwenden , um grub neu zu installieren. Es funktionierte wie ein Zauber, meinen Boot zu reparieren, nachdem ich Schritt 3 nicht abgeschlossen hatte, und noch einmal, als die Installation von Windows 10 die Linux-Boot-Option verschwinden ließ.

John
quelle
Ich habe eine Ubuntu-Festplatte und die Verwendung von Boot-Repair als Schritt 3 hat wie ein Zauber funktioniert!
Rael Gugelmin Cunha