मैं उबंटू के अनुकूलित संस्करण का एक ईएफआई-बूट करने योग्य आईएसओ कैसे बनाऊं?


16

मैंने अपना एक उबंटू वितरण बनाया है जिसे मैं अपने मैक पर बूट करना चाहता हूं (एक यूएसबी से)।

उबंटू वेबसाइट से मानक 64 बिट-उबंटू-आईएसओ का उपयोग करते समय, यह बूट करता है। हालाँकि, जब मेरे अपने वितरण वाली आइसो फ़ाइल के साथ सटीक काम करते हैं तो यह काम नहीं करता है, और यह केवल विरासत बूट का समर्थन करता है। हालाँकि, OS में / sys / फर्मवेयर / efi फ़ोल्डर है, इसलिए मुझे पता है कि यह EFI को सपोर्ट करता है। मैंने रेलिनो का उपयोग करके आइसो बनाया।

मैंने दो आईएसओ फाइलों के बीच अंतर को देखा है, और देखा है कि मानक ubuntu में एक EFI / BOOT फ़ोल्डर है जिसमें grubx64.efi और BOOTx64.EFI हैं, और एक बूट फ़ोल्डर भी है जो दूसरे में मौजूद नहीं है। मैंने इन दो निर्देशिकाओं, ईएफआई और बूट फ़ोल्डर को अपने अन्य यूएसबी में कॉपी करने की कोशिश की है, लेकिन काम नहीं करता है।

मेरा सवाल यह है कि:

  • मैं अपनी वर्तमान आईएसओ फ़ाइल में इन दो फ़ोल्डरों को कैसे प्राप्त कर सकता हूं?
  • और मैं अपने वितरण का एक आईएसओ कैसे बना सकता हूं ताकि वह ईएफआई बूट का समर्थन करे?

जवाबों:


18

आपको एक दोहरी बूट कैटलॉग ISO बनाने की आवश्यकता है ताकि वह EFI और MBR को बूट करे। मानक Ubuntu 14.04 x64 आईएसओ फ़ाइल इस तरह से काम करती है लेकिन EFI सिस्टम के लिए एक नया 14.04 बूट करने योग्य ISO बनाने के लिए कोई निर्देश उपलब्ध नहीं हैं। मैं इस तरह से आईएसओ बनाने के लिए एक साथ सही कदम उठाने में सक्षम था।

ये निर्देश आपको एक कस्टम Ubuntu 14.04 सर्वर ISO बनाने देंगे जो EFI और MBR को बूट कर सकते हैं। जब ईएफआई एक खाली, अनइंस्टॉलिज्ड डिस्क (उदाहरण के लिए हाइपर-वी में एक नई पीढ़ी 2 वीएम पर) के साथ एक सिस्टम पर बूट हो रहा है, तो सेटअप स्वचालित रूप से शुरू हो जाएगा, फिर स्वचालित रूप से डिस्क को मिटा देगा और आधार ubuntu-server संकुल और OpenHH स्थापित करेगा। यह LVM और ऑटो-विभाजन का उपयोग करके Ubuntu 14.04 के साथ नए सिस्टम को स्वचालित रूप से प्रोविज़न करने के लिए डिज़ाइन किया गया है। यदि आप एक मौजूदा लिनक्स सिस्टम पर इस आईएसओ का उपयोग करते हैं तो इंस्टॉलर बंद हो जाएगा जब यह मौजूदा डिस्क का पता लगाएगा और इनपुट की प्रतीक्षा करेगा। यदि आप इस आईएसओ का उपयोग एक गैर-ईएफआई प्रणाली पर करते हैं (उदाहरण के लिए एक जेनरेशन 1 हाइपर-वी वीएम) तो यह ग्राफिकल इंस्टॉलर स्टार्टअप स्क्रीन पर इंतजार करेगा और ऑटो इंस्टॉलर को जारी रखने से पहले इनपुट की आवश्यकता होगी।

परिणाम केवल ubuntu-server और ओपनश-सर्वर के साथ एक बेस उबंटू सर्वर इंस्टॉलेशन है।

यहां EFI-बूट करने योग्य ISO बनाने के चरण दिए गए हैं:

14.04 आईएसओ प्राप्त करें:

wget http://releases.ubuntu.com/14.04/ubuntu-14.04-server-amd64.iso

इसे माउंट करें और इसकी सामग्री को एक नए फ़ोल्डर में निकालें:

sudo mkdir -p ~/iso
sudo mount -o loop ubuntu-14.04-server-amd64.iso.iso ~/iso
sudo mkdir ~/ubuntu
sudo cp -rT ~/iso ~/ubuntu

निर्देशिका में बदलें जहाँ हम अपना काम करेंगे:

cd ~/ubuntu

भाषा को अंग्रेजी में सेट करें:

sudo -i
echo en >/home/user/ubuntu/isolinux/lang
exit

एक preseed फ़ाइल बनाएँ जो सभी उपलब्ध स्थान का उपयोग करके एलवीएम को डिस्क को ऑटो-पार्टिशन करने के लिए उपयोग करेगी:

sudo nano ~/ubuntu/ks.preseed

फ़ाइल सामग्री को इसके साथ बदलें:

d-i partman-auto/method string lvm
d-i partman-auto-lvm/guided_size string max
d-i partman-auto/choose_recipe select atomic
d-i partman-partitioning/confirm_write_new_label boolean true
d-i partman/confirm_write_new_label     boolean true
d-i partman/choose_partition            select  finish
d-i partman/confirm_nooverwrite         boolean true
d-i partman/confirm                     boolean true
d-i partman-auto/purge_lvm_from_device  boolean true
d-i partman-lvm/device_remove_lvm       boolean true
d-i partman-lvm/confirm                 boolean true
d-i partman-lvm/confirm_nooverwrite     boolean true
d-i partman-auto/init_automatically_partition       select      Guided - use entire disk and set up LVM
d-i partman/choose_partition                select      Finish partitioning and write changes to disk
d-i partman-auto-lvm/no_boot            boolean true
d-i partman-md/device_remove_md         boolean true
d-i partman-md/confirm                  boolean true
d-i partman-md/confirm_nooverwrite      boolean true

एक किकस्टार्ट फ़ाइल बनाएँ जो संस्थापन के दौरान उबंटू को विन्यस्त करेगी: (सुनिश्चित करें कि आप उपयोगकर्ता नाम भाग को बदलते हैं, और आपको कूटशब्द का प्रयोग करना चाहिए)

sudo nano ~/ubuntu/ks.cfg

फ़ाइल सामग्री को इसके साथ बदलें:

lang en_US
langsupport en_US
keyboard us
mouse
timezone America/Los_Angeles
rootpw --disabled
user USERNAME --fullname "USERNAME" --password "PASSWORD"
reboot
text
install
cdrom
auth  --useshadow  --enablemd5 
network --bootproto=dhcp --device=eth0
firewall --disabled 
skipx
%packages
@ ubuntu-server
openssh-server

ग्रब कॉन्फ़िगरेशन फ़ाइल को संपादित करें, ताकि जब ISO कोई EFI बूट करे तो बूटलोडर हमारी preseed और कॉन्फ़िगरेशन फ़ाइलों का उपयोग करने के लिए सही विकल्पों का उपयोग करे:

sudo nano ~/ubuntu/boot/grub/grub.cfg

फ़ाइल सामग्री को इसके साथ बदलें:

if loadfont /boot/grub/font.pf2 ; then
    set gfxmode=auto
    insmod efi_gop
    insmod efi_uga
    insmod gfxterm
    terminal_output gfxterm
fi

set menu_color_normal=white/light-blue
set menu_color_highlight=light-blue/light-gray
set timeout=10
set default=0

menuentry "Automatically Install Ubuntu Server with Custom Config" {
    set gfxpayload=keep
    linux   /install/vmlinuz  file=/cdrom/preseed/ubuntu-server.seed quiet ks=cdrom:/ks.cfg preseed/file=/cdrom/ks.preseed --
    initrd  /install/initrd.gz
}
menuentry "OEM install (for manufacturers)" {
    set gfxpayload=keep
    linux   /install/vmlinuz  file=/cdrom/preseed/ubuntu-server.seed quiet oem-config/enable=true --
    initrd  /install/initrd.gz
}
menuentry "Multiple server install with MAAS" {
    set gfxpayload=keep
    linux   /install/vmlinuz  modules=maas-enlist-udeb vga=788 initrd=/install/initrd.gz quiet --
    initrd  /install/initrd.gz
}
menuentry "Check disc for defects" {
    set gfxpayload=keep
    linux   /install/vmlinuz  MENU=/bin/cdrom-checker-menu quiet --
    initrd  /install/initrd.gz
}
menuentry "Rescue a broken system" {
    set gfxpayload=keep
    linux   /install/vmlinuz  rescue/enable=true --
    initrd  /install/initrd.gz
}

कस्टम कॉन्फ़िगरेशन और कस्टम preseed का उपयोग करने के लिए गैर- EFI बूटिंग (MBR बूटिंग) के लिए आइसोलिन बूट बूट मेनू को संपादित करें:

sudo nano ~/ubuntu/isolinux/txt.cfg

फ़ाइल सामग्री को इसके साथ बदलें:

default install
label install
  menu label ^Install Ubuntu Server with Custom Config
  kernel /install/vmlinuz
  append file=/cdrom/preseed/ubuntu-server.seed initrd=/install/initrd.gz ks=cdrom:/ks.cfg preseed/file=/cdrom/ks.preseed --
label cloud
  menu label ^Multiple server install with MAAS
  kernel /install/vmlinuz
  append   modules=maas-enlist-udeb vga=788 initrd=/install/initrd.gz quiet --
label check
  menu label ^Check disc for defects
  kernel /install/vmlinuz
  append   MENU=/bin/cdrom-checker-menu vga=788 initrd=/install/initrd.gz quiet --
label memtest
  menu label Test ^memory
  kernel /install/mt86plus
label hd
  menu label ^Boot from first hard disk
  localboot 0x80

आईएसओ बनाएं:

यह कमांड http://petersmithphotog.no-ip.biz/wiki/index.php/Unattended_Install पर दिखाया गया कमांड का संशोधित संस्करण है । वे निर्देश उबंटू 14.04 के लिए काम नहीं करते हैं क्योंकि वे फ़ाइल के लिए गलत स्थानों को इंगित करते हैं। (आईएसओ पर / boot/grub/ में होना चाहिए)

sudo mkisofs -U -A "Custom1404" -V "Custom1404" -volset "Custom1404" -J -joliet-long -r -v -T -o ../Custom1404.iso -b isolinux/isolinux.bin -c isolinux/boot.cat -no-emul-boot -boot-load-size 4 -boot-info-table -eltorito-alt-boot -e boot/grub/efi.img -no-emul-boot .

सत्यापित करें कि ISO में सही शैली के बूट कैटलॉग हैं:

मूल आईएसओ जिसे आपने उबंटू से डाउनलोड किया है:

dumpet -i ~/ubuntu-14.04-server-amd64.iso 

आउटपुट:

Validation Entry:
    Header Indicator: 0x01 (Validation Entry)
    PlatformId: 0x00 (80x86)
    ID: ""
    Checksum: 0x55aa
    Key bytes: 0x55aa
Boot Catalog Default Entry:
    Entry is bootable
    Boot Media emulation type: no emulation
    Media load segment: 0x0 (0000:7c00)
    System type: 0 (0x00)
    Load Sectors: 4 (0x0004)
    Load LBA: 8446 (0x000020fe)
Section Header Entry:
    Header Indicator: 0x91 (Final Section Header Entry)
    PlatformId: 0xef (EFI)
    Section Entries: 1
    ID: ""
Boot Catalog Section Entry:
    Entry is bootable
    Boot Media emulation type: no emulation
    Media load address: 0 (0x0000)
    System type: 0 (0x00)
    Load Sectors: 4672 (0x1240)
    Load LBA: 24754 (0x000060b2)

आपके द्वारा बनाया गया नया ISO:

dumpet -i ~/Custom1404.iso 

आउटपुट:

Validation Entry:
    Header Indicator: 0x01 (Validation Entry)
    PlatformId: 0x00 (80x86)
    ID: ""
    Checksum: 0x55aa
    Key bytes: 0x55aa
Boot Catalog Default Entry:
    Entry is bootable
    Boot Media emulation type: no emulation
    Media load segment: 0x0 (0000:7c00)
    System type: 0 (0x00)
    Load Sectors: 4 (0x0004)
    Load LBA: 3100 (0x00000c1c)
Section Header Entry:
    Header Indicator: 0x91 (Final Section Header Entry)
    PlatformId: 0xef (EFI)
    Section Entries: 1
    ID: ""
Boot Catalog Section Entry:
    Entry is bootable
    Boot Media emulation type: no emulation
    Media load address: 0 (0x0000)
    System type: 0 (0x00)
    Load Sectors: 4672 (0x1240)
    Load LBA: 1932 (0x0000078c)

आप इस आउटपुट की तुलना उस आउटपुट से कर सकते हैं, जिसे आप आईएसओ से प्राप्त निर्देशों के उपयोग से निर्मित करते हैं, मैं उबंटू की पूरी तरह से अनअटेंडेड स्थापना कैसे बना सकता हूं? : (वे एक एमबीआर केवल आईएसओ बनाते हैं, दोहरी बूट कैटलॉग आईएसओ नहीं)

sudo mkisofs -D -r -V "non-efi-ubuntu" -cache-inodes -J -l -b isolinux/isolinux.bin -c isolinux/boot.cat -no-emul-boot -boot-load-size 4 -boot-info-table -o ../non-efi-ubuntu.iso .

आईएसओ जानकारी प्राप्त करें:

dumpet -i ~/non-efi-ubuntu.iso 

आउटपुट:

Validation Entry:
    Header Indicator: 0x01 (Validation Entry)
    PlatformId: 0x00 (80x86)
    ID: ""
    Checksum: 0x55aa
    Key bytes: 0x55aa
Boot Catalog Default Entry:
    Entry is bootable
    Boot Media emulation type: no emulation
    Media load segment: 0x0 (0000:7c00)
    System type: 0 (0x00)
    Load Sectors: 4 (0x0004)
    Load LBA: 1925 (0x00000785)

2
यह एक EFI बूट करने योग्य ISO बनाने से अधिक काम करता है। इन निर्देशों से किकस्टार्ट और preseed विकल्पों को हटाकर आप एक मानक Ubuntu 14.04 ISO बना सकते हैं। उत्तर में विशिष्ट परिवर्तन नोट किए गए हैं।
दूसरा

1
फिर मैं आपसे अनुरोध करता हूं कि केवल प्रासंगिक अनुभाग यहां रखें, क्योंकि आपके पास पहले से ही सब कुछ के साथ अप्राप्य स्थापना प्रश्न पर एक उत्तर है।
मूरू

2
हाँ! मैं अनुकूलित फ़ोल्डर से एक EFI बूट करने योग्य आईएसओ बनाने के तरीके के लिए दूर-दूर तक खोज रहा हूं .. खुशी है कि आपने यहां सब कुछ एक ही स्थान पर रखा है!
एलेक्स आर

1
यह एक वर्चुअल मशीन में बहुत अच्छा काम करता है, लेकिन मैं इसे USB ड्राइव में कॉपी नहीं कर सकता, जैसे यह वनीला उबंटू इमेज के साथ करता है।
हरलेमस्केलर

2
@HarlemSquirrel, USB स्टिक से स्थापित करने के लिए, आपको ISO को USB ड्राइव बूट करने योग्य प्रारूप में बदलने के लिए बस एक और चरण की आवश्यकता है:# isohybrid path/to/image.iso
jjnebeker

1

UEFI ने USB ड्राइव को सक्षम किया

यदि आप USB मीडियम से इंस्टालेशन चाहते हैं, तो आपको पहले अनुकूलित ISO बनाने की आवश्यकता नहीं है।

UEFI- केवल बूटिंग USB लाइव मीडिया बनाना बहुत सीधे आगे है। बस अपने FAT32- स्वरूपित USB ड्राइव पर फ़ाइलों की प्रतिलिपि बनाएँ । बस! यह एक वैध यूईएफआई बूट माध्यम के रूप में पाया जाएगा।

फिर आप USB ड्राइव पर सीधे फ़ाइलों को संशोधित कर सकते हैं।

स्रोत और विवरण: UEFI- केवल बूट करने योग्य USB लाइव मीडिया कैसे बनाएं?


0

मेरे लिए सबसे अच्छा तरीका है:

1) सिस्टमबैक लाइव आइसो बनाएं

sudo apt-get install systemback
sudo apt-get install live-boot
sudo apt-get autoremove --purge casper

2) इस तरह से आईएसओ में एक uefi विभाजन जोड़ें:

cd /home
cat `ls -1 -t syst*.iso|head -1` efi.img >/tmp/live.iso
echo -e "n\np\n2\n\n\nt\n2\nef\nw\n"|fdisk /tmp/live.iso

3) iso को मीडिया में कॉपी करें (इस मामले में मेरा pendrive in / dev / sdb

pv /tmp/live.iso | dd of=/dev/sdb conv=notrunc,noerror
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.