AWS でカーネルを変更すると、ブートシーケンスが壊れるようです (grub 構成の問題でしょうか?)

AWS でカーネルを変更すると、ブートシーケンスが壊れるようです (grub 構成の問題でしょうか?)

AWS (ec2) で Ubuntu 20.04 を使用していて、カーネルを AWS から汎用カーネルに変更したいと考えていました。Grub Config を変更するという提案された方法を試したところ、マシンが停止してしまいました。

これは、Jibri (Jitsi Video Recorder) では ALSA の使用と modprobe snd-aloop が必要であるためですが、低レイテンシや異なるカーネルを必要とするものはすべて同じ要件があります。

私が試したこと:

画像を取得:

sudo apt install linux-image-extra-virtual

インストールパッケージにLinux 5.4.0-84-genericのようなものが参照されているのがわかると思います。これは後で役立ちます。次に、新しい汎用カーネルのブートエントリを一覧表示します。

grep -A200 submenu /boot/grub/grub.cfg |grep -P '^(?=.*menuentry)(?=.*generic)'

なるほど:

menuentry 'Ubuntu、Linux 5.4.0-84-generic 付き' --class ubuntu --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-5.4.0-84-generic-advanced-e8070c31-bfee-4314-a151-d1332dc23486' { menuentry 'Ubuntu、Linux 5.4.0-84-generic (リカバリモード) 付き' --class ubuntu --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-5.4.0-84-generic-recovery-e8070c31-bfee-4314-a151-d1332dc23486' {

おそらく一番上の行で、リカバリ モードについて言及している行ではない行の先頭にあるメニューエントリをコピーします。私の環境では、Linux 5.4.0-84-generic の Ubuntu のようですが、ユーザーによって異なります。

さて、編集しますデフォルト

GRUB_DEFAULT=0 (grub ブートリストの最初のエントリをロードします) をコメント アウトし、先ほど見つけた文字列に変更します。私の場合、ファイルのこのセクションは次のようになります。

#GRUB_DEFAULT=0
GRUB_DEFAULT="Ubuntu, with Linux 5.4.0-84-generic"

これはまだ適切な設定ではありません。GRUB にチェックさせて、最適な方法を教えてもらうために使用しています。

この時点で、sudo update-grub を実行すると、次のようなわかりやすい警告が表示されます (これは良いことです)。

Warning: Please don't use old title `Ubuntu, with Linux 5.4.0-84-generic' for GRUB_DEFAULT, use `Advanced options for Ubuntu>Ubuntu, with Linux 5.4.0-84-generic' (for versions before 2.00) or `gnulinux-advanced-e8070c31-bfee-4314-a151-d1332dc23486>gnulinux-5.4.0-84-generic-advanced-e8070c31-bfee-4314-a151-d1332dc23486' (for 2.00 or later)

これもいいですね! 認識できるものを指定したことはわかっています。最近は誰もが 2.00 より新しい grub を実行しているので、/etc/default/grub を再度編集して、最終的な値に変更します。

(私の価値観はあなたの価値観とは異なります)

#GRUB_DEFAULT=0
#GRUB_DEFAULT="Ubuntu, with Linux 5.4.0-84-generic"
GRUB_DEFAULT="gnulinux-advanced-e8070c31-bfee-4314-a151-d1332dc23486>gnulinux-5.4.0-84-generic-advanced-e8070c31-bfee-4314-a151-d1332dc23486"

sudo update-grub を実行すると、警告は消えます。

今私はsudo reboot now

この時点で、grub は、汎用カーネルを起動して通常のカーネルにフォールバックする構成を提供しました。

代わりに、ブート ループに陥ってしまいます。

シリアル コンソールでは、ブート ループ中にこれが繰り返し表示されます。

[    0.000000] Linux version 5.4.0-84-generic (buildd@lgw01-amd64-050) (gcc version 9.3.0 (Ubuntu 9.3.0-17ubuntu1~20.04)) #94-Ubuntu SMP Thu Aug 26 20:27:37 UTC 2021 
(Ubuntu 5.4.0-84.94-generic 5.4.133)
[    0.000000] Command line: BOOT_IMAGE=/boot/vmlinuz-5.4.0-84-generic root=PARTUUID=5198cbc0-01 ro console=tty1 console=ttyS0 nvme_core.io_timeout=4294967295 panic=-
1
[    0.000000] KERNEL supported cpus:
[    0.000000]   Intel GenuineIntel
[    0.000000]   AMD AuthenticAMD
[    0.000000]   Hygon HygonGenuine
[    0.000000]   Centaur CentaurHauls
[    0.000000]   zhaoxin   Shanghai  
... lots of cpu init that's hard to copy ..
[   10.366218] rtc_cmos 00:00: setting system clock to 2021-09-21T11:25:30 UTC (1632223530)
[   10.373185] md: Waiting for all devices to be available before autodetect
[   10.460173] md: If you don't use raid, use raid=noautodetect
[   10.464642] md: Autodetecting RAID arrays.
[   10.468024] md: autorun ...
[   10.470867] md: ... autorun DONE.
[   10.473906] VFS: Cannot open root device "PARTUUID=5198cbc0-01" or unknown-block(0,0): error -6
[   10.562806] Please append a correct "root=" boot option; here are the available partitions:
[   10.569825] Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-block(0,0)
[   10.674637] CPU: 1 PID: 1 Comm: swapper/0 Not tainted 5.4.0-84-generic #94-Ubuntu
[   10.682527] Hardware name: Amazon EC2 t3.small/, BIOS 1.0 10/16/2017
[   10.686735] Call Trace:
[   10.691100]  dump_stack+0x6d/0x8b
[   10.759061]  panic+0x101/0x2e3
[   10.761974]  mount_block_root+0x23f/0x2e8
[   10.765568]  mount_root+0x38/0x3a
[   10.768584]  prepare_namespace+0x13f/0x194
[   10.771873]  kernel_init_freeable+0x23f/0x263
[   10.775368]  ? rest_init+0xb0/0xb0
[   10.859141]  kernel_init+0xe/0x110
[   10.862101]  ret_from_fork+0x35/0x40
[   10.865843] Kernel Offset: 0x36a00000 from 0xffffffff81000000 (relocation range: 0xffffffff80000000-0xffffffffbfffffff)

ブートデバイスまたは partuid が見つからないと表示されます。この時点では、簡単に回復できないため、インスタンスを終了して再試行する必要があります。

カーネルを汎用カーネルに変更するより良い方法はありますか? 現時点では、起動できれば汎用イメージを何らかの方法で使用できれば満足です。

関連情報