支持 UEFI 的 USB 驱动器

支持 UEFI 的 USB 驱动器

我已经创建了自己的 Ubuntu 发行版,我想在我的 MAC 上(从 USB)启动它。

使用 Ubuntu 网站上的标准 64bit-Ubuntu-iso 时,它可以启动。但是,当对包含我自己的发行版的 iso 文件执行完全相同的操作时,它不起作用,并且它似乎仅支持传统启动。但是,操作系统有 /sys/firmware/efi 文件夹,所以我知道它支持 EFI。我使用 Relinux 制作了 iso。

我查看了两个 ISO 文件之间的差异,发现标准 ubuntu 有一个包含 grubx64.efi 和 BOOTx64.EFI 的 EFI/BOOT 文件夹,还有一个另一个中不存在的 boot 文件夹。我尝试将这两个目录(EFI 和 boot 文件夹)复制到我的另一个 USB 中,但没有成功。

我的问题是:

  • 我怎样才能将这两个文件夹放入我当前的 iso 文件中?
  • 我怎样才能制作我的发行版的 iso 以使其支持 EFI 启动?

答案1

您需要制作一个双启动目录 ISO,以便它可以启动 EFI 和 MBR。标准 Ubuntu 14.04 x64 ISO 文件以这种方式工作,但没有可用于为 EFI 系统制作新的 14.04 可启动 ISO 的说明。我能够拼凑出正确的步骤来创建这样的 ISO。

这些说明将帮助您创建可以启动 EFI 和 MBR 的自定义 Ubuntu 14.04 Server ISO。当在具有空白、未初始化磁盘的系统上启动 EFI 时(例如在 Hyper-V 中的新第二代 VM 上),安装程序将自动启动,然后自动擦除磁盘并安装基本 ubuntu-server 软件包和 OpenSSH。这旨在使用 LVM 和自动分区自动配置带有 Ubuntu 14.04 的新系统。如果您在现有 Linux 系统上使用此 ISO,则安装程序将在检测到现有磁盘时停止并等待输入。如果您在非 EFI 系统(例如第一代 Hyper-V VM)上使用此 ISO,则它将在图形安装程序启动屏幕上等待并要求输入,然后才能继续自动安装程序。

结果是仅包含 ubuntu-server 和 openssh-server 的基本 Ubuntu Server 安装。

以下是创建 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

创建一个 kickstart 文件,该文件将在安装过程中配置 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

编辑 grub 配置文件,以便当 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
}

编辑非 EFI 启动(MBR 启动)的 isolinux 启动菜单以使用自定义配置和自定义预置:

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 的错误位置。(应该位于 ISO 上的 ./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 具有正确样式的启动目录:

从 Ubuntu 下载的原始 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)

您可以将此输出与使用以下说明构建的 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)

答案2

支持 UEFI 的 USB 驱动器

如果您想从 USB 介质进行安装,则不需要先创建自定义 ISO。

创建仅支持 UEFI 的 USB Live 启动介质非常简单。只需将文件复制到FAT32 格式USB驱动器。就是这样! 它将被检测为有效的 UEFI 启动介质。

然后您可以直接在 USB 驱动器上修改文件。

来源和详细信息:如何创建仅 UEFI 可启动的 USB 实时媒体?

答案3

对我来说最好的方法是:

1)创建 systemback live iso

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

2)按如下方式向 iso 添加 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 位于 /dev/sdb

pv /tmp/live.iso | dd of=/dev/sdb conv=notrunc,noerror

相关内容