1. 问题背景
自己的台式机上装了好几块硬盘,因为自己又菜又喜欢折腾,几乎每块上都有一个操作系统,其中两个 m.2 的硬盘上分别装着一个 windows11 和一个 Ubuntu20.04。但在另外一块机械硬盘中还装着更早的一个 Ubuntu18.04,我电脑的启动引导也是这个系统的。
多个硬盘多个系统,导致了一个长期困扰着我的问题,我无法在 Ubuntu18.04 的启动引导中找到我的 Ubuntu20.04,而如果把启动盘设置为 Ubuntu20.04,它的启动引导中又无法找到我的 windows11。形成了一个奇妙的三角恋。
在终端中执行网上通常搜索出来的 update-grub2
根本没用,找不到就是找不到。今天又一次突发奇想,希望不依靠自动寻找,而是通过手动编辑 grub 的配置文件的方式来找到另一个系统。换了几个关键词搜索之后,终于成功了,记录一下过程。
2. 解决方案
grub 的 配置文件在 /boot/grub/grub.cfg
,我本来想直接编辑这个文件,但发现它是自动生成的只读文件。虽然是可以暴力地 chmod
已达到修改它的目的,但是下一次执行 update-grub2
的时候就会把你手动的修改覆盖掉,非常不优雅。
/boot/grub/grub.cfg
虽然不建议修改,但是它指出了一条手动修改 grub 的路,那就是去 /etc/grub.d/
路径下修改其中的脚本,在执行 update-grub2
的时候,grub 会根据这个路径下的脚本自动生成前面说的 cfg
配置文件。
于是我保存了一份 Ubuntu20.04 系统中的 /boot/grub/grub.cfg
到网盘,然后就重启进入了 Ubuntu18.04。
可以看到这个路径下的文件其实是有前缀的,00_,10_ 等,这个代表了执行顺序。/etc/grub.d/40_custom
这个文件是 grub 自带的模板文件,可以直接在这个脚本中添加我们希望添加的启动项。
从网盘中的 Ubuntu20.04 系统的 /boot/grub/grub.cfg
中搜索我要的 “Ubuntu20.04” 关键字,可以找到 menuentry
开头的、大括号包裹着的一段代码,直接复制粘贴到 /etc/grub.d/40_custom
中,保存退出。然后执行一下 update-grub2
。
重启,就可以看到我的 Ubuntu20.04 出现在了我的启动项中,完美!