无忧启动论坛

 找回密码
 注册
搜索
系统gho:最纯净好用系统下载站投放广告、加入VIP会员,请联系 微信:wuyouceo
楼主: 2011niumao
打印 上一主题 下一主题

[教程] 从 固定VHD与只读squashfs引导LINUX, UBUNTU ARCH Fedora Opensuse Mageia五种

    [复制链接]
541#
发表于 2022-9-14 17:02:49 | 只看该作者
本帖最后由 songjl1995 于 2022-9-14 17:18 编辑
2011niumao 发表于 2022-9-13 12:12
新系统ubuntu 22.04也没有问题可以制作成功的。你需要仔细检查制作过程,是不是都写对了。尤其是几个脚本 ...

用了大佬做的 initrd.img2204可以了,是我原先的Ubuntu20.04升级到22.04。
我自己做的重新查了边,把ntfs-3g的修改也加上了,目前自己做 initrd.img的也可以了。


但是我自己重新搞了个的ubuntu2204 vhd就不行,用您的 initrd.img2204也不行,是不是vhd在安装的时候出现逻辑分区了呀?

这个怎么确认下?(其实旧的2004升级上来已经没问题够用了,可以不折腾了,就是好奇出问题的原因)

点评

请说明一下出错的地方和出错的状态,以便排查原因。 比如,没有挂载好根目录失败---有可能是grub2菜单中 root=UUID=XXXXXX 那一段失效,可以用root=LABEL=XXXXX代替。以便正确识别挂载vhd文件所在的ntfs分区。  详情 回复 发表于 2022-9-14 18:08
回复

使用道具 举报

542#
 楼主| 发表于 2022-9-14 18:08:02 | 只看该作者
本帖最后由 2011niumao 于 2022-9-14 18:11 编辑
songjl1995 发表于 2022-9-14 17:02
用了大佬做的 initrd.img2204可以了,是我原先的Ubuntu20.04升级到22.04。
我自己做的重新查了边,把ntf ...

请说明一下出错的地方和出错的状态,以便排查原因。
比如,没有挂载好根目录失败---有可能是grub2菜单中 root=UUID=XXXXXX 那一段失效,可以用root=LABEL=XXXXX代替。以便正确识别挂载vhd文件所在的ntfs分区。另外注意动态 vhd 是 不行的,必须是固定大小的vhd, 最好是windows系统里管理工具创建的,这样成功率最大。如果没有编译安装ntfs-3g也不会正确挂载ntfs分区。
回复

使用道具 举报

543#
发表于 2022-9-14 19:53:14 | 只看该作者
看看如何引导LINUX系统啊
回复

使用道具 举报

544#
发表于 2022-9-27 10:10:39 | 只看该作者
2011niumao 发表于 2015-1-4 16:17
一般LINUX原理上应该都是可以的.但是具体实现由于命令不同变化很大.
例如ARCH上是 partx 命令 而不是  ...

请问不支持动态扩展大小的VHD是因为kpartx/partx的限制吗?
回复

使用道具 举报

545#
 楼主| 发表于 2022-9-27 13:55:00 | 只看该作者
Sandro 发表于 2022-9-27 10:10
请问不支持动态扩展大小的VHD是因为kpartx/partx的限制吗?

是的。可以使用nbd方式启动到动态大小硬盘,但有反应卡顿。
回复

使用道具 举报

546#
发表于 2022-9-27 18:07:03 | 只看该作者
2011niumao 发表于 2022-9-27 13:55
是的。可以使用nbd方式启动到动态大小硬盘,但有反应卡顿。

谢谢!nbd方式是指qemu-nbd吗?同时需要内核支持nbd?
回复

使用道具 举报

547#
 楼主| 发表于 2022-9-28 18:51:34 | 只看该作者
Sandro 发表于 2022-9-27 18:07
谢谢!nbd方式是指qemu-nbd吗?同时需要内核支持nbd?

是。
回复

使用道具 举报

548#
发表于 2022-10-3 22:57:51 | 只看该作者
根据网盘的pdf修文件后启动的系统是只读的
系统是mx linux 内核5.18.0
固定大小的vhd
看引导信息在加载NTFS分区时 提示非安全state  然后以只读加载了vhd,系统里的ntfs-3g是用网盘里编译的
=================
  •         insmod gzio
  •         insmod part_msdos
  •         insmod part_gpt
  •         insmod ext2
  •         insmod ntfs
  •         insmod probe
  •         set vhdfile="/mxlinx.vhd"
  •         set root=(hd0,1)
  •         search --no-floppy -f --set=aabbcc  $vhdfile
  •         set root=${aabbcc}
  •         probe -u --set=ddeeff ${aabbcc}
  •         loopback loop0 $vhdfile
  •         linux        (loop0,2)/vmlinuz root=UUID=$ddeeff rw kloop=$vhdfile kroot=/dev/mapper/loop0p2
  •         initrd        (loop0,2)/initrd.img

==================grub2 菜单基本是这样的 vhd有两个分区

回复

使用道具 举报

549#
 楼主| 发表于 2022-10-4 11:12:57 | 只看该作者
本帖最后由 2011niumao 于 2022-10-4 11:22 编辑
yzarc777 发表于 2022-10-3 22:57
根据网盘的pdf修文件后启动的系统是只读的
系统是mx linux 内核5.18.0
固定大小的vhd

如果启动时候,vhd文件所在分区是只读挂载时,vhd文件里的根分区也只能只读挂载---这样不能正确启动。
修正方法是,关闭windows的安全启动,快速启动模式。在windows系统下对vhd所在分区做一次磁盘分区检查,再重启就可以了。
回复

使用道具 举报

550#
发表于 2022-10-12 15:02:44 | 只看该作者
2011niumao 发表于 2022-8-18 10:06
这两天把ntfs-3g升级为2021版了,把grubsmall升级为2022版了,写了一个详细的 pdf 的新教程,

制作vhd的 ...

大佬,有个建议,你这更新了,能不能在首页记录一下,更新时间和更新说明在几楼,
比如这次:2022-08-18更新,详细说明在 526#楼 链接 http://bbs.wuyou.net/forum.php?m ... &fromuid=349519[/url]
这次是刚巧了看到了,怕回复多,不能及时看到最新的更新介绍
回复

使用道具 举报

551#
发表于 2022-10-12 20:41:15 | 只看该作者
本帖最后由 piazini 于 2022-10-12 23:29 编辑

大佬,这次的pdf文件总结的太好了,以前都是自己研究好,在总结出来,现在直接图文的,很明白。   
   
错误反馈。  
问题一:文件“制作vhd的ubuntu公共版.pdf”,第15页,           
            1.  虚线框里 ./configue  应该是 ./configure ,缺少了个r   ;
            2.  虚线框里 sudo make install 的 make 和 install 中间空格不明显,容易看成 makeinstall  ;
            3.  虚线框里 cd 后面应该是  cd ../ 吧  ;

问题二:文件“制作vhd的ubuntu公共版.pdf”,第21页,在脚本中没有 " local_premountroot " 只有 " local_premount " ,
            pdf 截图中也是不带root的     
问题三:文件“制作vhd的ubuntu公共版.pdf”,第20页,unset KLOOP=   截图中没有=号,但是 右侧虚线框里的有=号   

问题四:文件“制作vhd的ubuntu公共版.pdf”,第21页,if [ -z "$kloop" ] ; then kloop 是大写还是小写,pdf的23页截图是大写   




回复

使用道具 举报

552#
 楼主| 发表于 2022-10-12 21:56:41 | 只看该作者
piazini 发表于 2022-10-12 20:41
大佬,这次的pdf文件总结的太好了,以前都是自己研究好,在总结出来,现在直接图文的,很明白。   
   
...

好的,谢谢提醒,会修订!
回复

使用道具 举报

553#
发表于 2022-10-12 23:02:41 | 只看该作者
本帖最后由 piazini 于 2022-10-13 16:08 编辑


-


大佬好,用你的 " 制作vhd的ubuntu公共版.pdf " 制作 ubbuntu 22.04 启动VHD出现这个。

在虚拟机里安装好,是三个分区,我只把 ubuntu 的/目录分区,复制到了VHD ,和这个有没有关系?

还有引导,我也是用grub之前能启动18.04的VHD,和这个有没有关系?


--------------------------------------------------------------
2022-10-13_1535 更新:

确实和大佬说的,上面两张图都是空格的事。在这里回复,方便大家看到解决方法。   

1. 在 文件 " 制作vhd的ubuntu公共版.pdf ",第22页,有个 " ntfs-3g " 从pdf 复制到文件里变成 "  ntfs  -3g",两处都多了个空格;
2. 为了保险起见,又将  if后的方括号和分号间的空格全部替换了,  原来是 " ]   ;   then" 改成  " ];   then"
就是要多仔细检查,先看看行数对不对,再看有没有多空格。

回复

使用道具 举报

554#
 楼主| 发表于 2022-10-13 09:47:02 | 只看该作者
本帖最后由 2011niumao 于 2022-10-13 09:54 编辑
piazini 发表于 2022-10-12 23:02
大佬好,用你的 " 制作vhd的ubuntu公共版.pdf " 制作 ubbuntu 22.04 启动VHD出现这个。

在虚拟机里 ...

这个是vhd文件里面的根分区没有正确挂载。请仔细核对或重新制作一下内核初始镜像 initrd.img。
估计有一些语法错误的。特别要查看local文件里新加入的语句中,if 语句的 [ ]里面的空格,比如


  1. if  [  -z   "$KLOOP"   ]  &&   [   -z    "$SQUASHFS"    ] ; then
  2. 。。。。。。。。。
  3. if     [      -n         "$KLOOP"        ];      then
复制代码
我在空格上面栽过多次的。(那个pdf文件里代码的空格表现不明显)。



回复

使用道具 举报

555#
发表于 2022-10-13 15:40:22 | 只看该作者
本帖最后由 piazini 于 2022-10-15 21:28 编辑

下图一:

-
下图二

-
下图三

-
下图四

-
下图五



大佬,又出新状况了,
图一到图三,是启动过程的显示的,有一些显示 OK 了,有一些还不行。
图二就一直那样,到了 1分30秒后,才又继续执行
到图三就不动了,按了回车,就出现图四;
图五,我尝试输入 xstart 命令,想启动桌面,结果不成功

这是哪块的问题?   
--------------------------------------------------------------------------------------
2022-10-15 更新 :

解决方法:
1. 反复看 楼主的 pdf 文档,所有的细节都在里面了。
2. 函数里多余的空格删掉以外,我还把函数里多余的空行都删了。
3. 还有一点,经过测试,用Ubuntu22.04 的 iso 安装完的 VHD 就能正常引导,
如果是直接新创建一个VHD文件,用  DiskGenius 的克隆功能,
把旧 VHD 文件内容,克隆到新VHD里,引导就不成功或出现各种启动错误,如上面几张图。










回复

使用道具 举报

556#
发表于 2022-10-13 19:19:41 | 只看该作者
很实用的教程,多谢楼主了
回复

使用道具 举报

557#
发表于 2022-10-13 20:24:15 | 只看该作者
谢谢。
请问linux mint 21 也适用吗
回复

使用道具 举报

558#
 楼主| 发表于 2022-10-13 22:32:50 | 只看该作者
brux 发表于 2022-10-13 20:24
谢谢。
请问linux mint 21 也适用吗

可以的,mint基于ubuntu,做法应该一样。
回复

使用道具 举报

559#
 楼主| 发表于 2022-10-13 22:38:28 | 只看该作者

可能vhd所在硬盘分区有错误了,在windows下作一次磁盘分区检测即可。
也可能是vhd文件内部分区有错,这时可以在win下Vbox启动时在grub2菜单 linux语句后加上 recovery
然后引导,选择磁盘根分区检测,即可。
回复

使用道具 举报

560#
发表于 2022-10-14 06:33:35 | 只看该作者
谢谢大佬,

你的 " 制作vhd的ubuntu公共版.pdf "
第20页
unset KLOOP
unset KROOT
unset HOSTFSTYPE
unset KLOOPFSTYPE

后面都有=

实际应该是不要=的吧?
回复

使用道具 举报

561#
发表于 2022-10-14 12:11:11 | 只看该作者
新的折腾目标。学习下。
回复

使用道具 举报

562#
发表于 2022-10-14 16:58:47 | 只看该作者
先收藏,过段时间再学习。
回复

使用道具 举报

563#
发表于 2022-10-14 17:05:16 | 只看该作者

错误


vhd在hd1 硬盘 gpt3


vhd 里的 mint 系统分区如上 /分区在第三个区

请帮忙看下是否是菜单错误的问题
menuentry "启动 ubt.vhd 2" --class ubuntu {
        set gfxpayload=keep
        set root=(hd1,3)
        search --no-floppy -f --set=aabbcc /VHD/osmint/osmint/osmint.vhd
        set root=${aabbcc}
        probe -u --set=ddeeff ${aabbcc}
        linux         /VHD/osmint/osmint/vmlinuz  root=UUID=${ddeeff}  kloop=/VHD/osmint/osmint/osmint.vhd kroot=/dev/mapper/loop0p2
        initrd        /VHD/osmint/osmint/initrd.img
}


按大佬的 " 制作vhd的ubuntu公共版.pdf " 尝试了好多次 都不成功
不知道是不是local,init文件的问题, linuxmint 的 和 你提供的 ubuntu 的有些不一样


回复

使用道具 举报

564#
发表于 2022-10-14 17:17:19 | 只看该作者

对了  另外还写了个菜单
kroot=/dev/mapper/loop0p3
也一样的结果
回复

使用道具 举报

565#
发表于 2022-10-15 11:07:49 | 只看该作者
继续学习。我在MBR模式下成功,但EFI模式下进不去。

点评

赞!!! EFI模式引导,我有大量失败例子和成功例子。 主要原因是grub2的一些功能,比如查找文件,查找到文件后获取所在分区UUID等等。在UEFI模式下失效或者不能启动,导致系统找不到根分区。可以说 grub2的一些功  详情 回复 发表于 2022-10-15 13:58
回复

使用道具 举报

566#
 楼主| 发表于 2022-10-15 13:47:42 | 只看该作者
本帖最后由 2011niumao 于 2022-10-15 14:08 编辑
  1. menuentry "启动 ubt.vhd 2" --class ubuntu {
  2.         set gfxpayload=keep
  3.         set root=(hd1,3)
  4.         search --no-floppy -f --set=aabbcc /VHD/osmint/osmint/osmint.vhd
  5.         set root=${aabbcc}
  6.         probe -u --set=ddeeff ${aabbcc}
  7.         linux         /VHD/osmint/osmint/vmlinuz  root=UUID=${ddeeff}  kloop=/VHD/osmint/osmint/osmint.vhd kroot=/dev/mapper/loop0p2
  8.         initrd        /VHD/osmint/osmint/initrd.img
  9. }
复制代码

第一,按照你的描述,菜单里面,应该是/dev/mapper/loop0p3
第二,root=UUID=${ddeeff}这个没错,但经常也导致引导失败,主要是那个检测取得UUID的grub2功能
在有的机器上---特别是UEFI引导时---会有问题,此外UUID过长会导致分区识别错误(怀疑是不是root参数有长度限制,过长则截断了所以参数值错误)。
可以更改为 root=/dev/sdaX 这种格式,或者 root=/dev/LABEL/XXX 这中格式,当然卷标XXX必须纯英文。
第三,这个 /VHD/osmint/osmint/osmint.vhd 也太长了,会不会超过参数值的允许长度呢?最好是把vhd文件放在根分区下或者一级子目录下。目录太深长,不仅可能被截断,即使引导成功也会很卡顿的(我有过经验的)。
回复

使用道具 举报

567#
 楼主| 发表于 2022-10-15 13:58:53 | 只看该作者
本帖最后由 2011niumao 于 2022-10-15 14:05 编辑
huggsy 发表于 2022-10-15 11:07
继续学习。我在MBR模式下成功,但EFI模式下进不去。

赞!!!  EFI模式引导,我有大量失败例子和成功例子。

主要原因是grub2的一些功能,比如查找文件,查找到文件后获取所在分区UUID等等。在UEFI模式下失效或者不能启动,导致系统找不到根分区。可以说 grub2的一些功能在UEFI模式下被阉割了。

UEFI下要把菜单写死,不再考虑通用性。比如
  1. menuentry "UBT.vhd" --class ubuntu {
  2.         set gfxpayload=keep
  3.         insmod gzio
  4.         insmod part_msdos
  5.         insmod part_gpt
  6.         insmod ext2
  7.         insmod ntfs
  8.         insmod probe
  9.         set vhdfile=/texlive/ubt.vhd
  10.         set root=(hd0,1)
  11.         search.fs_uuid C850086250085998 root  
  12.         linux        /texlive/vmlinuz2004   root=UUID=C850086250085998 kloop=$vhdfile   kroot=/dev/mapper/loop0p2  selinux=0 audit=0
  13.         initrd        /texlive/initrd.img2004
  14. }
复制代码

这里使用的是先找到vhd文件所在分区的UUID  C850086250085998,写死在菜单里。这种写法UEFI下引导成功。
search.fs_uuid C850086250085998 root
这条grub2命令是 查找指定UUID的分区,并把它设为根分区。

回复

使用道具 举报

568#
发表于 2022-10-15 21:48:15 | 只看该作者
本帖最后由 piazini 于 2022-10-15 22:09 编辑

2011niumao大佬,

在ubt18.04的VHD扩容,直接用 DiskGenius 克隆功能,复制到新 VHD 文件里,就完成扩容了,

但是在ubt22.04里,我用这样的方法,引导就会出现不同的错误,虽然能引导成功(并不是每次都成功),
启动过程中有好多"失败",有部分显示“OK”,所以用ISO镜像安装完的VHD文件,引导启动时都显示OK。

initrd.img 和 vmlinuz 是没问题的(备份、替换、编译initrd.img都是我写好的脚本自动完成的),
用ISO安装时,分区里有个安装 “引导器” ,是不是克隆时候 ,引导器克隆不过去,DiskGenius 克隆是按文件访问的,底层数据读不到。

经过测试,ISO 镜像安装时,"引导器"不管装在 sda 还是 sda1 用 DiskGenius 克隆后,VHD启动都不正常。

是和用ntfs-3g_ntfsprogs-2021.8.22-fixed.zip 有关系么? 之前 ubt18 用的是2017的那个。

我还发现,用ISO装完的VHD 显示扇区是 33 , 0~32是不是"引导器",但用 DiskGenius 克隆后的VHD 扇区是 2 。

那扩容要怎么弄才能最方便呢? 不能扩容就要重装一次系统吧



回复

使用道具 举报

569#
发表于 2022-10-15 22:02:03 | 只看该作者
2011niumao 发表于 2022-10-15 13:47
第一,按照你的描述,菜单里面,应该是/dev/mapper/loop0p3
第二,root=UUID=${ddeeff}这个没错,但经 ...

谢谢大佬的耐心回复

更改了vhd路径到C盘 /VHD文件夹下,使用root=UUID=248681088680DC24 也还是无法启动。

请问下 root=UUID=, 和root=/dev/sdaX, root=/dev/LABEL/XXX 这里的root还是vhd所在硬盘分区吧。

谢谢,不想折腾mint vhd了,我觉得可能还是mint的init local 那几个文件和ubuntu不同有关,过段时间换ubunt vhd再试试。
回复

使用道具 举报

570#
 楼主| 发表于 2022-10-16 10:12:13 | 只看该作者
本帖最后由 2011niumao 于 2022-10-16 10:28 编辑
brux 发表于 2022-10-15 22:02
谢谢大佬的耐心回复

更改了vhd路径到C盘 /VHD文件夹下,使用root=UUID=248681088680DC24 也还是无法启 ...

是,root总是指vhd文件所在分区。其中,sdaX指分区序号,主分区1,2,3,4,逻辑分区是 5 6 7 这样的。
LABEL指卷标,不能有汉字,只能是英文。

另外,这些只是排查引导信息错误。其实更应该注意 local 文件里的语法错误,特别是各个 if 语句中方括号[ ]里的空格问题。很多错误都源自于local文件里的错误。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|捐助支持|无忧启动 ( 闽ICP备05002490号-1 )

闽公网安备 35020302032614号

GMT+8, 2024-11-23 23:09

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表