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-pc
weiterhin anstelle von verwendet grub-efi
.
Wie kann ich Ubuntu von EFI booten lassen?
Antworten:
Inhaltsverzeichnis:
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
gptfdisk
odergdisk
abhängig von der Distribution (Ubuntu nennt esgdisk
). 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) Partitionsgröße ändern
Verwenden Sie
parted
(Befehlszeile) odergparted
(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
Ändern Sie das Gerät, das Sie konvertieren möchten
/dev/sdx
.Es sollte Ihnen mitteilen, dass die Partitionstabelle konvertiert wird.
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.
Sie sollten jetzt die EFI-Partition haben.
Dann geh
gdisk
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 :
Sie sollten herausfinden, mit welcher Version von grub-efi Sie installieren möchten
Wenn es heißt,
EFI32
installieren Sie dasgrub-efi-ia32
Paket, wenn es heißt,EFI64
installieren Sie dasgrub-efi-amd64
Paket. Sie können die Pakete mit installierenDies 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-efi
Installation 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
Es wird davon ausgegangen, dass Windows
hd0
von GRUB erkannt wird. Es muss möglicherweise geändert werden,hd1
um zu arbeiten.Jetzt lauf
um die Konfigurationsdatei zu aktualisieren.
Referenzen und weiterführende Literatur
Ich habe mehrere Quellen verwendet.
quelle
grub-pc
,grub-efi
wenn Sie die Live-CD entfernen und installieren (bevor Sie sie installieren?)?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 ichgrub-efi
Partitionen 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-efi
Sie wechseln möchten/boot/efi
. Fügen Sie dies zu/etc/fstab
¹ hinzugrub-efi
PaketUEFI and Legacy
aufUEFI 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-pc
erneut.¹: 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/sdb3
oder such². Sie müssen dann das/boot/efi
Verzeichnis erstellen und eine Zeile hinzufügen/etc/fstab
. Wenn Ihre EFI-Partition ist/dev/sdb3
, würden Sie die folgende Zeile hinzufügen:Sobald Sie ausgeführt haben
sudo mount /boot/efi
, sollten Sie feststellen, dass/boot/efi
einEFI
Verzeichnis 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/sda2
Name 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:Ich weiß, dass
/dev/sda1
es sich bei meiner EFI-Systempartition handeltin meinem
/etc/fstab
.quelle
Disk utility
Programm finden. Solange Sie Ihre EFI-Partitiongrub-efi
nicht gefunden und gemountet haben , funktioniert sie nicht. Sie muss ihren Bootloader in die EFI-Systempartition stecken.sudo grub-install
undsudo update-grub
installieren 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.create partition efi
. Informationen zu diskpart finden Sie unter technet.microsoft.com/en-us/library/cc766465%28WS.10%29.aspxIdealerweise ist mindestens eine primäre Partition in der Partitionstabelle frei.
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-bin
Paket und folgen Sie den Anweisungen unter Hinzufügen eines ESP zu einer vorhandenen Installation mit MBR, die mit aktuellen Ubuntu-Versionen funktionieren sollte.quelle
diskpart
,dism /apply-image
dannbcdboot
(weitere Optionen auf diese beiden natürlich) , um es mbr make install oder gpt unabhängig davon , wie Sie gestartet.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ß.
quelle