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 が見つからないと表示されます。この時点では、簡単に回復できないため、インスタンスを終了して再試行する必要があります。
カーネルを汎用カーネルに変更するより良い方法はありますか? 現時点では、起動できれば汎用イメージを何らかの方法で使用できれば満足です。