आपको एक दोहरी बूट कैटलॉग 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)