Pertanyaan Bagaimana saya bisa mengubah / mengubah drive MBR Ubuntu ke GPT, dan membuat boot Ubuntu dari EFI?


Saya baru saja memperbarui PC saya, Motherboard baru saya (ASUS M5A99X EVO) menggunakan UEFi sebagai ganti opsi MBR biasa.

Saya memiliki instalasi Ubuntu 11.10 yang saya lakukan ketika saya memiliki perangkat keras sebelumnya (MSI MS 7267), Ubuntu sendiri baik-baik saja, dan begitu juga Windows 7, namun Windows 7 menggunakan boot UEFI (GPT) sedangkan Ubuntu menggunakan MBR.

Saya memiliki OS saya di drive yang terpisah, sehingga GRUB2 tidak akan digantikan oleh Windows Bootloader dan viceversa, karena saya mengatakan kedua OS baik boot sendiri, tetapi untuk melakukan itu saya harus memutuskan satu drive dalam hal ini drive Ubuntu sebagai itu mencegah Windows dari loading.

Sekarang pertanyaan saya adalah, Bagaimana saya dapat mengubah / mengkonversi drive Ubuntu sehingga alih-alih menggunakan MBR menggunakan GPT dan memungkinkan Windows untuk boot ?.

Lebih disukai tanpa menginstal ulang seluruh sistem atau kehilangan data apa pun.

Dan jika saya harus menghapus drive, Bagaimana saya bisa menginstal Ubuntu di GPT, UEFI, apa pun itu mode ?.

Saya telah menggunakan gdisk untuk mengkonversi dari MBR ke GPT, tetapi sekarang Ubuntu tidak bisa boot sepertinya grub tidak mulai.

Saya telah menginstal ulang OS, dan drive ini sekarang adalah GPT secara default grup-pc masih digunakan, bukan grub-efi.

Bagaimana saya bisa membuat boot Ubuntu dari EFI ?.


56
2017-12-02 04:12


asal


Semoga ini akan membantu Anda rodsbooks.com/gdisk/booting.html. - One Zero


Jawaban:


Daftar Isi:

  1. Terminologi
  2. Mengkonversi
  3. Mengkonfigurasi (+ Dual boot)

Terminologi

BIOS = Sistem Input / Output Dasar

(U) EFI = (Unified) Extensible Firmware Interface

MBR = Master Boot Record

GPT = GUID Partition Table

UEFI / EFI / BIOS = Antarmuka firmware

MBR / GPT = Bagaimana komputer mengetahui (per hard disk) partisi apa yang ada di drive dan cara boot dari mereka.

UEFI / BIOS

SEBUAH antarmuka firmware adalah cara firmware (perangkat lunak di dalamnya perangkat) dan sistem operasi berinteraksi. Ini menginisialisasi perangkat keras kemudian berjalan sistem operasi dan memastikan bahwa driver sistem operasi dapat beroperasi  perangkat keras.

BIOS telah menjadi antarmuka firmware biasa yang telah digunakan. UEFI adalah antarmuka yang lebih baru yang memiliki beberapa fitur, seperti menjadi lebih cepat, memiliki GUI dan dapat memulai kartu jaringan dan mendapatkan alamat ip. UEFI menggantikan EFI. (Mereka yang mengembangkan EFI melihat bahwa ada orang lain yang melakukan hal serupa dan bergabung dengan mereka, membawa ide-ide EFI bersama mereka. Ini kemudian menjadi UEFI).

BIOS membutuhkan bootloader untuk menjadi awal disk, namun UEFI menggunakan partisi untuk ini dan dapat memilih di antara beberapa boot loader untuk digunakan.

MBR / GPT + GRUB

Itu MBR adalah bagian kode di awal disk yang berisi boot loader (untuk BIOS), serta peta partisi dan pengidentifikasi disk yang unik.

Untuk menginstal GRUB ke disk dengan MBR, GRUB menempatkan program kecil di MBR memuat sisa GRUB dari bagian lain dari disk. (Ini dilakukan karena MBR terlalu kecil untuk memuat semua GRUB). Ruang yang dipilih adalah ruang antara MBR dan partisi pertama, yang biasanya ada.

GPT adalah standar untuk bagaimana partiton ditentukan. Itu memang memiliki 'pelindung' MBR, namun ini hanya untuk memungkinkan komputer berbasis BIOS untuk boot dan berhenti alat yang hanya tahu tentang MBR dari mencoba membuang sampah GPT. Itu bisa

(Bagaimana GPT ditangani tergantung pada apakah itu boot menggunakan BIOS (atau sistem UEFI dalam mode emulasi BIOS) atau UEFI. Saya akan fokus pada UEFI karena berkaitan dengan pertanyaan).

Boot loader untuk sistem operasi disimpan dalam bagian yang disebut Sistem EFI Partiton, yang diformat (biasanya) dengan FAT32. Di sinilah GRUB diinstal.

Mengkonversi

Pertama...

Kami bermain-main dengan tabel partisi, jadi dijamin tidak aman mungkin. Ini adalah operasi yang berisiko. Namun, metode ini tidak boleh kehilangan data.

Orang lain menemukan ini: Jangan gunakan di Apple Mac.

Sekarang...

Anda perlu melakukan ini pada live CD (atau instalasi linux lain yang diinstal ke disk yang berbeda.)

Ketika berhadapan dengan disk GPT, kita perlu menggunakan program sadar GPT. 'GPT fdisk' adalah alat yang bagus untuk digunakan dan apa yang akan saya gunakan. Itu bisa disebut gptfdisk atau gdisk tergantung pada distribusi (Ubuntu menyebutnya gdisk). Berpisah (dan Gparted) juga GPT sadar, sehingga dapat 'aman' digunakan dengan GPT disk.

Untuk mengkonversi Anda perlu:

  1. Ubah ukuran partisi agar sesuai dengan data GPT dan partisi sistem EFI.
  2. Konversi disk dan tambahkan partisi
  3. Instal GRUB ke partisi sistem EFI.

1) Ubah ukuran partisi

Menggunakan parted (baris perintah) atau gparted (GUI) untuk mengubah ukuran yang pertama dan terakhir partisi. Bagian pertama harus memiliki sekitar 200MiB sebelumnya, dan yang terakhir partisi harus memiliki 1MiB hingga 2MiB (dapat dilakukan) yang diambil dari bagian akhir.

2) Konversi disk

Menjalankan

gdisk /dev/sdx

mengubah perangkat yang ingin Anda konversi /dev/sdx.

Ini harus memberitahu Anda bahwa itu akan mengkonversi tabel 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): 

Sekarang tambahkan partisi baru, membuatnya menjadi tipe 'sistem EFI'. Ini harus menemukan yang gratis ruang di awal (saya sarankan beberapa nomor sektor rendah seperti 34) dan secara otomatis menggunakan semua ruang kosong. Contoh-contoh menggunakan USB flash drive 4GB dengan 1 partisi sudah ada di sana, diubah ukurannya seperti di atas.

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'

Anda seharusnya sudah memiliki partisi 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

Lalu keluar 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.

Sekarang gunakan Gparted (atau baris perintah mkfs.vfat) untuk memformat partisi sebagai FAT32.

3) Instal GRUB

Ini datang dengan sedikit jaminan bahwa bagian sebelumnya karena saya belum mencobanya sendiri.

Saya tidak yakin tentang langkah ini, jadi saya akan menebaknya Instruksi RAOF:

Untuk beralih ke grub-efi yang Anda inginkan

  1. Temukan partisi EFI Anda; pasang di / boot / efi. Tambahkan ini ke / etc / fstab¹
  2. Instal paket grub-efi
  3. Alihkan prioritas boot BIOS Anda dari UEFI dan Legacy ke UEFI saja (atau opsi serupa)

Anda harus mengetahui versi grub-efi mana yang harus diinstal

ioreg -l -p IODeviceTree | grep firmware-abi

Jika dikatakan EFI32 instal grub-efi-ia32 paket, jika dikatakan EFI64  instal grub-efi-amd64 paket. Anda dapat menginstal paket dengan

sudo apt-get install <package name>

Ini mungkin hanya akan berfungsi jika Anda telah boot dalam mode EFI.

Jika tidak berhasil, Anda bisa mencoba ini petunjuk langkah demi langkah (di bawah "Instal GRUB2 dalam sistem (U) EFI") satu kali grub-efi diinstal.

Mengkonfigurasi (+ Dual Boot)

Jika petunjuk RAOK berfungsi, Anda harus dapat menambahkan baris berikut ke /etc/grub.d/40_custom

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

Ini mengasumsikan bahwa Windows diakui sebagai hd0 oleh GRUB. Mungkin perlu diubah untuk hd1 untuk bekerja.

Sekarang jalankan

update-grub

untuk memperbarui file konfigurasi.

Referensi dan bacaan lebih lanjut

Saya menggunakan beberapa sumber.


95
2017-12-07 14:20



WOah, terima kasih! .. tapi saya masih terjebak menginstal grub-efi ke drive, saya telah menginstal ulang OS dan membuat drive GPT, tetapi masih menggunakan grub-pc tidak grub-efi. - Uri Herrera
Jika Anda memiliki pilihan (karena saya tidak memiliki perangkat UEFI yang saya lumpuhkan karena bisa membantu), Anda perlu mem-boot live CD dalam mode UEFI dan bukan mode BIOS / MBR. - Portablejim
Bagaimana dengan menghapus grub-pc dan menginstal grub-efi sementara di live cd (sebelum Anda menginstal mungkin?)? - Portablejim
Yah saya membuat liveusb dengan Unetbootin di bawah jendela dan ada folder efi di dalamnya karena Windows, jadi saya kira ini tidak mewakili masalah, mungkin saya punya grub-efi sekarang dan saya bahkan belum menyadarinya, saya ' Saya akan menerima jawaban Anda sekarang. - Uri Herrera
Wow, ini bekerja dengan sempurna, terima kasih! Saya baru saja migrasi instalasi paralel Fedora 25 dan Windows 10 dari MBR + BIOS ke GPT + UEFI tanpa menginstal ulang apa pun. Saya telah melakukan langkah 1 dan 2 dari tongkat USB Fedora 25 Live boot dengan UEFI. Untuk langkah 3, saya menggunakan chroot untuk mengakses sistem saya yang ada dari sistem Live seperti yang dijelaskan di bawah wiki.ubuntuusers.de/GRUB_2/Reparatur/#chroot-Methode . Saya telah menghapus grub2, menginstal grub2-efi dan grub2-efi-modules dan secara eksplisit menginstal ulang shim (tanpa menginstal ulang shim, menu Grub tidak akan muncul). Akhirnya ... - Philipp Hartwig


Jawaban ini tidak lengkap; Saya belum menguji semua ini. Tidak mungkin memakan data Anda, tetapi Anda telah diperingatkan!

Apa yang saya kira yang terjadi di sini adalah bahwa BIOS Anda adalah istimewa boot dari MBR warisan, sehingga UEFI Windows 7 miskin tua semakin diabaikan.

Salah satu hal baik tentang UEFI adalah Anda tidak perlu lagi khawatir tentang Windows yang menimpa GRUB; mereka berdua harus hidup berdampingan dengan baik di partisi EFI. Oleh karena itu, satu opsi adalah untuk beralih ke grub-efi. catatan: Saya tidak yakin apakah itu grub-efi memahami partisi-style MSDOS; saya berpikir itu benar. Jika tidak, ini akan gagal untuk boot, dan Anda akan membutuhkan LiveCD untuk pulih. Bahkan, memiliki LiveCD yang berguna pula!

Untuk beralih ke grub-efi kamu ingin

  1. Temukan partisi EFI Anda; pasang di /boot/efi. Tambahkan ini ke /etc/fstab¹
  2. Instal grub-efi paket
  3. Alihkan prioritas boot BIOS Anda dari UEFI and Legacy untuk UEFI only (atau opsi serupa)

Bahwa harus meninggalkan Anda dengan menginstal Ubuntu UEFI-booting. Jika tidak, boot LiveCD Anda yang terpercaya (atau Ubuntu Alternate install CD - opsi "Perbaiki sistem rusak" adalah apa yang Anda cari), chroot ke dalam sistem Anda, dan instal grub-pc lagi.


¹: Detail lebih lanjut untuk langkah ini: Anda harus menemukan apa yang kernel Linux sebut partisi sistem EFI Anda. Ini akan menjadi sesuatu seperti /dev/sda2, /dev/sdb3, atau semacam itu. Anda harus membuatnya /boot/efi direktori, dan tambahkan baris ke /etc/fstab. Jika partisi EFI Anda /dev/sdb3, maka Anda akan menambahkan baris berikut:

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

Setelah Anda jalankan sudo mount /boot/efi Anda kemudian harus menemukan itu /boot/efi mengandung a EFI direktori, dengan subdirektori untuk Windows 7.


²: Karena Anda memiliki banyak hard drive, mungkin itu adalah ide yang baik untuk mengetahui UUID partisi, karena itu akan stabil di bawah penambahan / penghapusan harddrives sedangkan /dev/sda2 nama tidak dijamin tidak akan berubah. Ini dapat dilakukan setelah Anda selesai mengatur segalanya, meskipun.

Anda dapat menemukan UUID dengan mencari tahu /dev/disk/by-uuid. Sebagai contoh, saya mendapatkan:

$ 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

Dalam kasus saya, saya tahu /dev/sda1 adalah partisi sistem EFI saya, jadi saya punya

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

di saya /etc/fstab.


9
2017-12-02 06:28



Jika Windows 7 melakukan boot dari EFI, maka ia akan menempatkan bootloadernya di partisi EFI - jadi Anda harus punya satu. Ini akan tidak dapat dilihat di mana saja di sistem file standar Ubuntu. Anda harus menemukannya dengan sesuatu seperti Disk utility program. Sampai Anda menemukan dan memasang partisi EFI Anda, grub-efi tidak akan bisa bekerja - ia perlu menempelkan bootloadernya di partisi sistem EFI. - RAOF
Masih tidak bisa boot ke Ubuntu, saya telah menambahkan baris ke fstab menggunakan livecd dan juga menciptakan direktori efi di / boot tetapi tampaknya tidak memiliki efek apa pun. - Uri Herrera
Sekarang setelah Anda memasang partisi EFI, Anda harus menjalankan sudo grub-install dan sudo update-grub untuk benar-benar menginstal dan mengatur GRUB di partisi EFI. Anda harus melakukan ini setelah melakukan chroot ke dalam instalasi Anda (karena perlu mengetahui hal-hal tentang penginstalan pada hard drive Anda). Jika Anda perlu bantuan, saya dapat menambahkan detail untuk jawabannya. - RAOF
Ya, silakan tambahkan cara chroot ke instal saya dan instal ulang grub. - Uri Herrera
Saya mengikuti instruksi di sini, tapi saya punya masalah dengan partisi EFI yang baru. Ketika saya mencoba memasang jendela 10 pratinjau, pemasang memberikan kesalahan ini: "Windows mendeteksi bahwa partisi sistem EFI diformat sebagai NTFS. Memformat partisi sistem EFI sebagai FAT32 dan memulai ulang instalasi" Saya dapat menyelesaikan masalah dengan menggunakan alat diskpart yang datang dengan penginstal windows, dengan menghapus partisi EFI pertama dan membuat yang lain dengan create partition efi. Untuk info tentang diskpart, lihat technet.microsoft.com/en-us/library/cc766465%28WS.10%29.aspx - Pathogen


Saya memiliki OS saya di drive yang terpisah, sehingga GRUB2 tidak akan digantikan oleh Windows Bootloader dan viceversa

Itu ideal, jadi Anda cenderung memiliki setidaknya satu partisi utama gratis di tabel partisi.

Sekarang pertanyaan saya adalah, Bagaimana saya bisa mengubah / mengkonversi drive Ubuntu sehingga daripada menggunakan MBR menggunakan GPT dan memungkinkan Windows untuk boot?

Anda tidak perlu mengonversi MBR ke GPT untuk melakukan booting UEFI, cukup buat partisi FAT primer, instal grub-efi-amd64-bin paket dan ikuti petunjuk di Tambahkan ESP ke instalasi yang sudah ada dengan MBR yang seharusnya bekerja dengan rilis Ubuntu saat ini.


2
2018-01-27 09:40



Jawaban di bawah nilai. Windows dengan keras membutuhkan booting GPT + UEFI atau MBR + BIOS, tetapi Linux memungkinkan mix-and-match dan grub dapat mem-chainload disk lain atau mem-boot bootmgr Windows 7 secara langsung. - Tim G
@timg Ini mungkin benar setelah fakta tetapi sayangnya jika Anda menyiapkan Windows 10 dari awal, tampaknya penginstal tidak akan membiarkan Anda melanjutkan tanpa volume GPT, jika Anda mem-boot EFI. - Merk
@Merk Oh, saya menggunakan installer Windows dengan cara yang berbeda: Shift-F10 memberi Anda baris perintah dan Anda bisa diskpart, dism /apply-image, kemudian bcdboot (lebih banyak opsi pada keduanya tentu saja) untuk membuatnya menginstal mbr atau gpt terlepas dari bagaimana Anda boot. - Tim G


Untuk melengkapi Jawaban Portablejim (yang sangat membantu saya untuk mengkonversi dari MBR ke GPT, terima kasih!), Anda dapat menggunakan Boot-Repair menginstal ulang grub. Ini bekerja seperti pesona untuk memperbaiki boot saya setelah saya gagal menyelesaikan langkah 3, dan sekali lagi ketika instalasi Windows 10 membuat opsi boot linux hilang.


0
2017-11-27 23:36