Я создал собственное распределение Ubuntu, которое я хочу загрузить (от USB) на моем MAC.
При использовании стандартного 64bit-Ubuntu-iso с веб-сайта Ubuntu это загружается. Однако при выполнении той же самой вещи с файлом ISO, содержащим мое собственное распределение, это не работает, и это, кажется, только поддерживает начальную загрузку прежней версии. Однако ОС имеет/sys/firmware/efi папку, таким образом, я знаю, что она поддерживает EFI. Я сделал ISO с помощью Relinux.
Я посмотрел на различия между двумя файлами ISO и видел, что стандартная человечность имеет папку EFI/BOOT, содержащую grubx64.efi и BOOTx64. EFI, и также имеет папку начальной загрузки, которая не существует в другом. Я попытался скопировать эти два каталога, EFI и папку начальной загрузки в мой другой USB, но не работает.
Мой вопрос:
, Если Вы хотите Установку от Носителя USB, Вы не должны создавать специализированный ISO сначала.
Создание, UEFI-только загружающее USB живые медиа, является довольно прямым. Просто скопируйте файлы в Ваш FAT32-отформатированный Карта памяти. Вот именно! Это будет обнаружено как действительный Носитель Начальной загрузки UEFI.
Затем можно изменить файлы непосредственно на Карте памяти.
Источник и Детали: , Как создать UEFI-только загрузочный USB живые медиа?
Для меня лучший способ:
1) создают systemback живая ISO
sudo apt-get install systemback
sudo apt-get install live-boot
sudo apt-get autoremove --purge casper
2), добавляет uefi раздел к ISO таким образом:
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 в/dev/sdb
pv /tmp/live.iso | dd of=/dev/sdb conv=notrunc,noerror
Необходимо сделать каталог двойной загрузки ISO так, чтобы он загрузил EFI и MBR. Стандартная Ubuntu 14.04 x64 файл ISO прокладывает себе путь, но нет никаких инструкций, доступных для создания новых 14,04 загрузочных ISO для систем EFI. Я смог соединить правильные шаги для создания ISO как это.
Эти инструкции позволят Вам создать пользовательский Сервер Ubuntu 14.04 ISO, который может загрузить EFI и MBR. Когда EFI, загружающийся в системе с пробелом, неинициализированный диск (например, на новом поколении 2 VM в Hyper-V), установка запустится автоматически, затем автоматически, вытрет диск и установит основные пакеты сервера человечности и OpenSSH. Это разработано для того, чтобы автоматически настроить новые системы с Ubuntu 14.04 с помощью LVM и авторазделения. При использовании этого ISO в существующей системе Linux затем, установщик остановится, когда это обнаружит существующие диски, и ожидайте входа. При использовании этого ISO в системе не-EFI (например, Поколение 1 Hyper-V VM) затем, он будет ожидать в графической экранной заставке установщика и требовать входа прежде, чем продолжиться к автоматическому установщику.
Результатом является основная установка Сервера Ubuntu с сервером человечности и openssh-сервером только.
Вот шаги для создания загрузочного EFI ISO:
Получите 14,04 ISO:
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
Создайте файл перед семенем, который будет использовать LVM, чтобы авторазделить диск, использующий все свободное пространство:
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
Создайте запускать файл, который настроит Ubuntu во время установки: (удостоверьтесь, что Вы изменяете часть имени пользователя, и необходимо использовать зашифрованные пароли),
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 загружаются, загрузчик использует правильные опции использовать наше предварительное семя и конфигурационные файлы:
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
}
Отредактируйте меню начальной загрузки изо-Linux для начальной загрузки не-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
Создайте ISO:
Эта команда является измененной версией команды, показанной по http://petersmithphotog.no-ip.biz/wiki/index.php/Unattended_Install. Те инструкции не работают на Ubuntu 14.04, потому что они указывают на неправильные местоположения для файла efi.img. (должен быть в./boot/grub/на ISO),
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 имеет корректные каталоги начальной загрузки стиля:
Исходный ISO Вы загрузили с Ubuntu:
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)
Можно ли сравнить этот вывод с выводом, который Вы получаете от ISO, созданного с помощью инструкций в том, Как я создаю абсолютно необслуживаемую установку Ubuntu?: (они создают MBR только ISO, не каталог двойной загрузки ISO),
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 .
Получите информацию о 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)