内蔵HDDをいつくかのバーティションに分けて、Windows 10 + Ubuntu 18.04 + Ubuntu 20.04 のトリプルブート環境を構築したのです。
今まではWin10とUbuntu 18.04のデュアルブートでメインの使用はUbuntu。
何故こんなことをしたかというと、Ubuntuを20.04にアップグレードする前に、うちのPC上で 20.04がちゃんと動作するかどうか確かめたかったから、18.04とは別の場所にお試しインストールしてみたのです。実際にインストールしてみないと分からないこともありますからね。
動作検証の結果、20.04は無難に動作はするものの、差し当たって急いでアップグレードする程でもない、という感じ。
で、試用も済んだので、要らない20.04を削除しよう(20.04をインストールしたパーティションを初期化してしまおう)…と思ったのだけど、システムのブート時に、後からインストールした20.04のgrub設定を読み込むようになってしまっているのだな。
このまま20.04を即刻削除してしまうと、何か良からぬことが起きるであろうと想像されます。18.04のほうの grub設定を読むように変更しておかなくては。作業の方針は…
- パーティションの状況を確認。
- ブートの設定を確認。
- ブート設定を書き換え。
- 起動することを確認。
- 要らない20.04を削除。
間違った操作をすると、システムが起動しなくなるなどの致命的な不具合が生じる可能性があります。
理屈を十分理解した上で、自己責任でお願いします。
まず、パーティション操作ツールのGParted*を起動して、HDDのパーティションを確認してみる。関係部分だけ書き出すと以下のような感じ。
- /dev/sda1 : EFI system partition : ブートローダーをインストールした場所
- /dev/sda3 : Windows 10
- /dev/sda5 : Ubuntu 18.04
- /dev/sda6 : Ubuntu 20.04
この他に、赤丸のところに /dev/sda1 は /boot/efi にマウントされている という情報も表示されています。/boot/efi 以下を覗いてみると、/boot/efi/EFI/ubuntu/grub.cfg というファイルが見つかるので、中身を見てみましょ。
ルート権限が必要なので、
と、管理者権限をゲットしておいて、
を実行。出力は…
set prefix=($root)'/boot/grub'
configfile $prefix/grub.cfg
となりました。xxxx-xxx-xxxxxxx は Ubuntu 20.04 をインストールしたパーティション(/dev/sda6)の UUID。
つまり、
という設定になっていることがわかります。これを18.04の当該ファイルを参照するように書き換えてやれば良いのではないかな。
というわけで、18.04 のパーティション(/dev/sda5)のUUIDを調べます。
結果の出力は、
zzz-zzz-zzzがsda5のUUIDであることがわかります。この情報を元にブートローダーのgrub.cfgを書き換え。
set prefix=($root)'/boot/grub'
configfile $prefix/grub.cfg
ファイルを保存したらシステムを再起動してみます。どきどき。
問題がなければ、システムは無事に起動して、18.04上で設定したgrubメニューが表示される筈。
あとは不要になった20.04のパーティションを初期化したり削除したり、ご自由に。
もしGPartedがインストールされていなければ、
コメント