我已经提取了iso文件“archlinux-2022.06.01-x86_64.iso”。我已经在“airootfs.sfs”文件中进行了更改
现在我将再次创建一个“可启动(dos/MBR 扇区)”iso 映像,就像我提取的原始 iso 文件一样
sudo xorriso -as mkisofs -d -l -r -no-emul-boot
-o archlinux.iso .
-append_partition 2 0xef ../compile-linux/efi_part.img -e "--interval:appended_partition_2:all::" -no-emul-boot ../compile-linux/bios_boot.img
-G ../compile-linux/mbr_code.img
-b syslinux/isolinux.bin
-c syslinux/boot.cat
输出file archlinux.iso
archlinux.iso: ISO 9660 CD-ROM filesystem data (DOS/MBR boot sector) 'ISOIMAGE' (bootable)
输出命令xorriso -indev archlinux.iso -report-el-torito plain -report-system-area plain
xorriso 1.5.4 : RockRidge filesystem manipulator, libburnia project.
xorriso : NOTE : Loading ISO image tree from LBA 0
xorriso : UPDATE : 114 nodes read in 1 seconds
xorriso : NOTE : Detected El-Torito boot information which currently is set to be discarded
Drive current: -indev 'archlinux.iso'
Media current: stdio file, overwriteable
Media status : is written , is appendable
Boot record : El Torito , MBR cyl-align-off
Media summary: 1 session, 445804 data blocks, 871m data, 178g free
Volume id : 'ISOIMAGE'
El Torito catalog : 42 1
El Torito cat path : /syslinux/boot.cat
El Torito images : N Pltf B Emul Ld_seg Hdpt Ldsiz LBA
El Torito boot img : 1 BIOS y none 0x0000 0x00 76 43
El Torito img path : 1 /syslinux/isolinux.bin
System area options: 0x00000a00
System area summary: MBR cyl-align-off
ISO image size/512 : 1783216
Partition offset : 0
MBR heads per cyl : 64
MBR secs per head : 32
MBR partition table: N Status Type Start Blocks
MBR partition : 1 0x00 0x83 0 1783216
MBR partition : 2 0x00 0xef 1783216 1600
上面的输出是我自己制作的iso文件
我尝试在虚拟机“Efi 选项已禁用”中使用我的 iso 文件,但出现这些错误。
我是初学者,对此不太了解
这就是为什么我试图找到正确的方法来从原始 iso 输出中制作图像,但我没有成功
xorriso 1.5.4 : RockRidge filesystem manipulator, libburnia project.
xorriso : NOTE : ISO image bears MBR with -boot_image any partition_offset=16
xorriso : NOTE : Loading ISO image tree from LBA 0
xorriso : UPDATE : 113 nodes read in 1 seconds
libisofs: NOTE : Found hidden El-Torito image for EFI.
libisofs: NOTE : EFI image start and size: 396800 * 2048 , 0 * 512
xorriso : NOTE : Detected El-Torito boot information which currently is set to be discarded
Drive current: -indev '../archlinux-2022.06.01-x86_64.iso'
Media current: stdio file, overwriteable
Media status : is written , is appendable
Boot record : El Torito , MBR isohybrid cyl-align-all GPT
Media summary: 1 session, 440998 data blocks, 861m data, 178g free
Volume id : 'ARCH_202206'
El Torito catalog : 118 1
El Torito cat path : /syslinux/boot.cat
El Torito images : N Pltf B Emul Ld_seg Hdpt Ldsiz LBA
El Torito boot img : 1 BIOS y none 0x0000 0x00 4 119
El Torito boot img : 2 UEFI y none 0x0000 0x00 0 396800
El Torito img path : 1 /syslinux/isolinux.bin
El Torito img opts : 1 boot-info-table isohybrid-suitable
El Torito img blks : 2 44032
System area options: 0x00000302
System area summary: MBR isohybrid cyl-align-all GPT
ISO image size/512 : 1763992
Partition offset : 16
MBR heads per cyl : 64
MBR secs per head : 32
MBR partition table: N Status Type Start Blocks
MBR partition : 1 0x80 0x00 64 1587136
MBR partition : 2 0x00 0xef 1587200 176128
GPT : N Info
GPT disk GUID : 3230323230363041b130303533353232
GPT entry array : 2 248 separated
GPT lba range : 64 1763928 1763991
GPT partition name : 1 490053004f00480079006200720069006400
GPT partname local : 1 ISOHybrid
GPT partition GUID : 1 3230323230363041b131303533353232
GPT type GUID : 1 a2a0d0ebe5b9334487c068b6b72699c7
GPT partition flags: 1 0x1000000000000001
GPT start and size : 1 64 1587136
GPT partition name : 2 490053004f004800790062007200690064003100
GPT partname local : 2 ISOHybrid1
GPT partition GUID : 2 3230323230363041b132303533353232
GPT type GUID : 2 a2a0d0ebe5b9334487c068b6b72699c7
GPT partition flags: 2 0x1000000000000001
GPT start and size : 2 1587200 176128
我哪里做错了?我正在尝试创建 ISO 映像文件并实时使用它
感谢您的帮助
答案1
您的 xorriso -as mkisofs 运行至少缺少 -e 及其修改选项和 -b 及其修改选项之间的分隔符 -eltorito-alt-boot 。因此,您的结果 ISO 缺少 EFI 的 El Torito 条目,因为 -e 被 -b 覆盖。
无论如何,ISOLINUX 的失败不能归咎于这个缺点。我想这与缺少 -b 的修改选项有关。
您可以向 xorriso 询问有关重放可启动 ISO 的启动相关选项的建议(如果 ISO 是由 xorriso 制作的,则效果最佳)。为了正确分析 Archlinux ISO,您需要 xorriso-1.5.4 或更高版本,因为旧版本不需要使用引导选项的组合。
$ xorriso -indev archlinux-2022.06.01-x86_64.iso -report_el_torito as_mkisofs
...
-V 'ARCH_202206'
--modification-date='2022060115352200'
-isohybrid-mbr --interval:local_fs:0s-15s:zero_mbrpt,zero_gpt:'archlinux-2022.06.01-x86_64.iso'
-partition_cyl_align all
-partition_offset 16
-partition_hd_cyl 64
-partition_sec_hd 32
--mbr-force-bootable
-append_partition 2 0xef --interval:local_fs:1587200d-1763327d::'archlinux-2022.06.01-x86_64.iso'
-iso_mbr_part_type 0x00
-c '/syslinux/boot.cat'
-b '/syslinux/isolinux.bin'
-no-emul-boot
-boot-load-size 4
-boot-info-table
-eltorito-alt-boot
-e '--interval:appended_partition_2_start_396800s_size_176128d:all::'
-no-emul-boot
-boot-load-size 0
-isohybrid-gpt-basdat
并非所有这些都必须给出,因为有些是 ISO 特有的(-V 'ARCH_202206' --modification-date='2022060115352200')。有些并不是真正需要的,因为 xorriso 可以自己计算出来(-partition_cyl_align all -partition_hd_cyl 64 -partition_sec_hd 32 -boot-load-size 0)。
与您的选项列表相比,我敢打赌这是无法从(虚拟)光学介质通过 BIOS 启动的直接原因:
- 缺少 -b 修改选项:-no-emul-boot -boot-load-size 4 -boot-info-table(嗯,-no-emul-boot 错误生效。)
但还有更多问题:
缺少 -eltorito-alt-boot,因此无法通过光学介质启动 EFI。
缺少 -e 修改选项 -isohybrid-gpt-basdat,因此没有 GPT 可以通过 USB 记忆棒通过挑剔的 EFI 实现进行引导。
缺少 -isohybrid-mbr,因此无法从 USB 记忆棒通过 BIOS 启动。相反,有一个多余的 -G 和一个模糊的 MBR 图像 mbr_code.img (你从哪里得到这个?)
模糊的输入文件 ../compile-linux/bios_boot.img 将被映射到 ISO 的根目录。
-b 和 -e 的顺序相反,但应该没问题。 EFI 映像的引导加载大小 0 是正确的,因为它太大,无法在引导目录中列出其实际大小(限制为 32 MiB)。
使用 xorriso-1.5.4 将有一种更简单的方法来操作 Archlinux ISO:
xorriso -indev archlinux-2022.06.01-x86_64.iso \
-outdev archlinux.iso \
... xorriso manipulation commands like -map or -rm ... \
-boot_image any replay
(xorriso 问题和支持请求最好提交给 [电子邮件受保护].)
祝你今天过得愉快 :)
托马斯
答案2
archlinux-2022.06.01-x86_64.iso
总共可启动四不同的方式:
- 作为 BIOS 模式下的(真实或虚拟)ISO9660 CD/DVD
- 作为 UEFI 模式下的(真实或虚拟)ISO9660 CD/DVD
- 作为 BIOS 模式下的 HDD 映像
- 作为 UEFI 模式下的 HDD 映像
根据archiso
配置文件配置,UEFI 引导模式甚至包括用于 64 位和 32 位 x86 UEFI 实现的两个单独的引导加载程序(x64
在ia32
UEFI 术语中),因此您可以说它总共有六启动模式。
创造这样的野兽很复杂,Arch 有一个专用工具archiso
为了这份工作——我想这是有充分理由的。我建议您也许应该尝试使用它,而不是尝试重新发明轮子。源代码archiso
可以在Gitlab中找到,如果您发现需要自定义它。
如果我xorriso
正确地解释了该报告,您的 ISO 映像声称只能通过两种方式启动:
- 作为 BIOS 模式下的(真实或虚拟)ISO9660 CD/DVD
- 作为 UEFI 模式下的 HDD 映像(但仅具有 MBR 分区表)
此外,在您的映像上,引导记录状态显示cyl-align-off
为与 相反 isohybrid cyl-align-all
,这表明 ISO 映像的各个组件可能未正确对齐。
在真实的 Arch ISO 上,MBR 指示第一个分区(主要 Iiso9660 文件系统内容)可在 BIOS 模式下启动(状态 0x80),并且分区类型 ID 为 0x00,这是 ISO9660 文件系统的典型情况,因为它们没有标准 MBR分配的分区类型 ID。在您的映像上,MBR 声明第一个分区不可启动,并且类型 ID 为 0x83,这将是ext4
或其他 Linux 文件系统的预期值。