UbuntuのカスタマイズバージョンのEFIブート可能ISOを作成するにはどうすればよいですか?


16

MACで(USBから)起動したい独自のUbuntuディストリビューションを作成しました。

Ubuntu Webサイトから標準の64bit-Ubuntu-isoを使用すると、起動します。ただし、独自のディストリビューションを含むisoファイルでまったく同じことを行うと機能せず、レガシーブートのみをサポートするように見えます。ただし、OSには/ sys / firmware / efiフォルダーがあるため、EFIをサポートしていることがわかります。Relinuxを使用してisoを作成しました。

2つのISOファイルの違いを調べましたが、標準のubuntuにはgrubx64.efiとBOOTx64.EFIを含むEFI / BOOTフォルダーがあり、もう一方には存在しないブートフォルダーもあることがわかりました。これら2つのディレクトリ、EFIとブートフォルダーを他のUSBにコピーしようとしましたが、機能しません。

私の質問は:

  • これら2つのフォルダーを現在のisoファイルに取得するにはどうすればよいですか?
  • そして、どうすればEFIブートをサポートするようにディストリビューションのisoを作成できますか?

回答:


18

EFIとMBRをブートするために、デュアルブートカタログISOを作成する必要があります。標準のUbuntu 14.04 x64 ISOファイルはこの方法で機能しますが、EFIシステム用の新しい14.04ブート可能ISOを作成するための指示はありません。このようなISOを作成するための正しい手順をまとめることができました。

これらの手順により、EFIおよびMBRを起動できるカスタムUbuntu 14.04サーバーISOを作成できます。初期化されていない空のディスクがあるシステム(たとえば、Hyper-Vの新しいGeneration 2 VM)でEFIを起動すると、セットアップが自動的に開始され、ディスクが自動的にワイプされ、ベースのubuntu-serverパッケージとOpenSSHがインストールされます。これは、LVMと自動パーティション分割を使用してUbuntu 14.04で新しいシステムを自動的にプロビジョニングするために設計されています。既存のLinuxシステムでこのISOを使用する場合、インストーラーは既存のディスクを検出し、入力を待機するときに停止します。非EFIシステム(第1世代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を使用して、使用可能なすべてのスペースを使用してディスクを自動パーティション化する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

インストール中に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ブートを実行するときに、ブートローダーが適切なオプションを使用して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
}

非EFIブート(MBRブート)のisolinuxブートメニューを編集して、カスタム構成とカスタムpreseedを使用します。

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に示されているコマンドの修正バージョンです。これらの指示は、efi.imgファイルの間違った場所を指しているため、Ubuntu 14.04では機能しません。(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)

この出力を、Ubuntuの完全無人インストールを作成する方法の手順を使用して構築されたISOから取得した出力と比較できます。:(デュアルブートカタログISOではなく、MBRのみの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
EFIブート可能ISOを作成するだけではありません。これらの手順からキックスタートとpreseedオプションを削除することにより、標準のUbuntu 14.04 ISOを作成できます。特定の変更が回答に記載されています。
anothermh

1
それから、関連するセクションのみをここに残しておくようにお願いします。なぜなら、あなたはすでに他のすべての無人インストールの質問に対する答えを持っているからです。
ムル14

2
はい!カスタマイズされたフォルダからEFIブータブルISOを作成する方法を幅広く探していました。
アレックスR

1
これは仮想マシンでうまく機能しますが、バニラUbuntuイメージの場合のようにUSBドライブにコピーしたときにこれを起動できません。
ハーレムリス

2
@ HarlemSquirrel、USBスティックからインストールするには、ISOをUSBドライブのブータブル形式に変換するためのもう1つの手順が必要です# isohybrid path/to/image.iso
。– jjnebeker

1

UEFI対応USBドライブ

USBメディアからのインストールが必要な場合、最初にカスタマイズされたISOを作成する必要はありません。

UEFIのみの起動USBライブメディアの作成は簡単です。ファイルをFAT32形式の USBドライブにコピーするだけです。それでおしまい! 有効なUEFIブートメディアとして検出されます。

その後、USBドライブ上のファイルを直接変更できます。

ソースと詳細:UEFIのみのブータブルUSBライブメディアを作成する方法


0

私にとって最良の方法は次のとおりです。

1)システムバックライブ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をメディアにコピーします(この場合、/ dev / sdbにあるペンドライブ)

pv /tmp/live.iso | dd of=/dev/sdb conv=notrunc,noerror
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.