Chat-GPTに聞いてみたところ、いくつかの可能性を提示してくれた。
LinuxでNum Lockのランプが点灯し、システムが終了しない場合、以下のような原因が考えられます:
1. カーネルパニック
• システムの内部で致命的なエラーが発生しており、操作ができなくなっている可能性があります。
• 兆候: Num Lockランプが点灯・点滅することがよく見られます。
• 対応策:
• エラーログを確認する:
再起動後に/var/log/kern.logまたはjournalctlでエラーを確認してください。
sudo journalctl -b -1
(-1で前回のブートログを表示)
• カーネルやドライバをアップデートする。
2. ハードウェアの問題
• ハードウェア(特にメモリやディスク)の問題が原因で、システムがフリーズしている可能性があります。
• 対応策:
• メモリ診断: memtest86を使用してメモリの異常を確認します。
• ディスク診断:
スマートテストを実行して、ストレージデバイスを確認します。
sudo smartctl -a /dev/sdX # Xを適切なディスク名に置き換え
3. ACPIや電源管理の問題
• 一部のハードウェアでは、電源管理の設定が適切に機能しない場合があります。
• 兆候: シャットダウン時に停止するが、電源が切れない。
• 対応策:
• 起動オプションにacpi=offまたはapm=offを試す。
• GRUB設定を編集し、GRUB_CMDLINE_LINUX_DEFAULTにオプションを追加:
sudo nano /etc/default/grub
# 例:
GRUB_CMDLINE_LINUX_DEFAULT=”quiet splash acpi=off”
sudo update-grub
4. ドライバやモジュールの問題
• 特定のドライバやモジュールがシャットダウン中に問題を引き起こしている場合があります。
• 対応策:
• シャットダウンの過程で何が起きているかを詳細表示するため、グラフィカルロゴを無効にしてみます:
sudo nano /etc/default/grub
# “quiet splash”を削除
GRUB_CMDLINE_LINUX_DEFAULT=””
sudo update-grub
5. キーボードロックの可能性
• Num Lockランプが点灯しているだけで、実際には他の問題が原因でフリーズしている場合もあります。
• 対応策:
• SysRqキーを試す:
キーボードでAlt + SysRq(PrintScreenキー)を押しながら以下を順に入力:
reisub
(安全に再起動を試みる)
• SysRqが有効か確認:
cat /proc/sys/kernel/sysrq
1でなければ有効にする:
sudo echo “1” > /proc/sys/kernel/sysrq
6. ファイルシステムの問題
• ファイルシステムが破損していると、シャットダウンプロセスで問題が発生する可能性があります。
• 対応策:
• 再起動後にファイルシステムチェックを実行:
sudo fsck /dev/sdX
まずはエラーログや状況を確認し、それに基づいて対処を進めてください。問題が特定できない場合、使用中のディストリビューションやカーネルバージョンを教えていただければ、さらに具体的なアドバイスが可能です。
そこで、今回、ACPIや電源管理の問題 を試してみた。
- GRUB設定を編集し、GRUB_CMDLINE_LINUX_DEFAULTにオプションを追加:
sudo nano /etc/default/grub
例:
GRUB_CMDLINE_LINUX_DEFAULT=”quiet splash acpi=off”
sudo update-grub
ところが、
bash: update-grub: コマンドが見つかりませんでした…
と言われてしまいました。
そこで、次のようにしてみました。
[root@AMULET4 grub2]# grub2-mkconfig
Generating grub configuration file …
#
# DO NOT EDIT THIS FILE
#
# It is automatically generated by grub2-mkconfig using templates
# from /etc/grub.d and settings from /etc/default/grub
#
### BEGIN /etc/grub.d/00_header ###
set pager=1
if [ -f ${config_directory}/grubenv ]; then
load_env -f ${config_directory}/grubenv
elif [ -s $prefix/grubenv ]; then
load_env
fi
if [ “${next_entry}” ] ; then
set default=”${next_entry}”
set next_entry=
save_env next_entry
set boot_once=true
else
set default=”${saved_entry}”
fi
if [ x”${feature_menuentry_id}” = xy ]; then
menuentry_id_option=”–id”
else
menuentry_id_option=””
fi
export menuentry_id_option
if [ “${prev_saved_entry}” ]; then
set saved_entry=”${prev_saved_entry}”
save_env saved_entry
set prev_saved_entry=
save_env prev_saved_entry
set boot_once=true
fi
function savedefault {
if [ -z “${boot_once}” ]; then
saved_entry=”${chosen}”
save_env saved_entry
fi
}
function load_video {
if [ x$feature_all_video_module = xy ]; then
insmod all_video
else
insmod efi_gop
insmod efi_uga
insmod ieee1275_fb
insmod vbe
insmod vga
insmod video_bochs
insmod video_cirrus
fi
}
terminal_output console
if [ x$feature_timeout_style = xy ] ; then
set timeout_style=menu
set timeout=5
# Fallback normal timeout code in case the timeout_style feature is
# unavailable.
else
set timeout=5
fi
### END /etc/grub.d/00_header ###
### BEGIN /etc/grub.d/00_tuned ###
set tuned_params=””
set tuned_initrd=””
### END /etc/grub.d/00_tuned ###
### BEGIN /etc/grub.d/01_users ###
if [ -f ${prefix}/user.cfg ]; then
source ${prefix}/user.cfg
if [ -n “${GRUB2_PASSWORD}” ]; then
set superusers=”root”
export superusers
password_pbkdf2 root ${GRUB2_PASSWORD}
fi
fi
### END /etc/grub.d/01_users ###
### BEGIN /etc/grub.d/08_fallback_counting ###
insmod increment
# Check if boot_counter exists and boot_success=0 to activate this behaviour.
if [ -n “${boot_counter}” -a “${boot_success}” = “0” ]; then
# if countdown has ended, choose to boot rollback deployment,
# i.e. default=1 on OSTree-based systems.
if [ “${boot_counter}” = “0” -o “${boot_counter}” = “-1” ]; then
set default=1
set boot_counter=-1
# otherwise decrement boot_counter
else
decrement boot_counter
fi
save_env boot_counter
fi
### END /etc/grub.d/08_fallback_counting ###
### BEGIN /etc/grub.d/10_linux ###
insmod part_gpt
insmod xfs
if [ x$feature_platform_search_hint = xy ]; then
search –no-floppy –fs-uuid –set=root 8f23ffac-0d13-40b8-835d-f778147d9c2e
else
search –no-floppy –fs-uuid –set=root 8f23ffac-0d13-40b8-835d-f778147d9c2e
fi
insmod part_gpt
insmod fat
if [ x$feature_platform_search_hint = xy ]; then
search –no-floppy –fs-uuid –set=boot 59FA-E2F1
else
search –no-floppy –fs-uuid –set=boot 59FA-E2F1
fi
# This section was generated by a script. Do not modify the generated file – all changes
# will be lost the next time file is regenerated. Instead edit the BootLoaderSpec files.
#
# The blscfg command parses the BootLoaderSpec files stored in /boot/loader/entries and
# populates the boot menu. Please refer to the Boot Loader Specification documentation
# for the files format: https://www.freedesktop.org/wiki/Specifications/BootLoaderSpec/.
# The kernelopts variable should be defined in the grubenv file. But to ensure that menu
# entries populated from BootLoaderSpec files that use this variable work correctly even
# without a grubenv file, define a fallback kernelopts variable if this has not been set.
#
# The kernelopts variable in the grubenv file can be modified using the grubby tool or by
# executing the grub2-mkconfig tool. For the latter, the values of the GRUB_CMDLINE_LINUX
# and GRUB_CMDLINE_LINUX_DEFAULT options from /etc/default/grub file are used to set both
# the kernelopts variable in the grubenv file and the fallback kernelopts variable.
if [ -z “${kernelopts}” ]; then
set kernelopts=”root=UUID=85e9f883-4cb1-41c3-b5ff-41d68e37b2de ro crashkernel=auto resume=UUID=5d770573-28ef-469d-bbb9-686c6514cd33 rhgb quiet acpi=off “
fi
insmod blscfg
blscfg
### END /etc/grub.d/10_linux ###
### BEGIN /etc/grub.d/10_reset_boot_success ###
# Hiding the menu is ok if last boot was ok or if this is a first boot attempt to boot the entry
if [ “${boot_success}” = “1” -o “${boot_indeterminate}” = “1” ]; then
set menu_hide_ok=1
else
set menu_hide_ok=0
fi
# Reset boot_indeterminate after a successful boot
if [ “${boot_success}” = “1” ] ; then
set boot_indeterminate=0
# Avoid boot_indeterminate causing the menu to be hidden more then once
elif [ “${boot_indeterminate}” = “1” ]; then
set boot_indeterminate=2
fi
# Reset boot_success for current boot
set boot_success=0
save_env boot_success boot_indeterminate
### END /etc/grub.d/10_reset_boot_success ###
### BEGIN /etc/grub.d/12_menu_auto_hide ###
if [ x$feature_timeout_style = xy ] ; then
if [ “${menu_show_once}” ]; then
unset menu_show_once
save_env menu_show_once
set timeout_style=menu
set timeout=60
elif [ “${menu_auto_hide}” -a “${menu_hide_ok}” = “1” ]; then
set orig_timeout_style=${timeout_style}
set orig_timeout=${timeout}
if [ “${fastboot}” = “1” ]; then
# timeout_style=menu + timeout=0 avoids the countdown code keypress check
set timeout_style=menu
set timeout=0
else
set timeout_style=hidden
set timeout=1
fi
fi
fi
### END /etc/grub.d/12_menu_auto_hide ###
### BEGIN /etc/grub.d/20_linux_xen ###
### END /etc/grub.d/20_linux_xen ###
### BEGIN /etc/grub.d/20_ppc_terminfo ###
### END /etc/grub.d/20_ppc_terminfo ###
### BEGIN /etc/grub.d/30_os-prober ###
### END /etc/grub.d/30_os-prober ###
### BEGIN /etc/grub.d/30_uefi-firmware ###
Adding boot menu entry for EFI firmware configuration
menuentry ‘System setup’ $menuentry_id_option ‘uefi-firmware’ {
fwsetup
}
### END /etc/grub.d/30_uefi-firmware ###
### BEGIN /etc/grub.d/35_fwupd ###
### END /etc/grub.d/35_fwupd ###
### BEGIN /etc/grub.d/40_custom ###
# This file provides an easy way to add custom menu entries. Simply type the
# menu entries you want to add after this comment. Be careful not to change
# the ‘exec tail’ line above.
### END /etc/grub.d/40_custom ###
### BEGIN /etc/grub.d/41_custom ###
if [ -f ${config_directory}/custom.cfg ]; then
source ${config_directory}/custom.cfg
elif [ -z “${config_directory}” -a -f $prefix/custom.cfg ]; then
source $prefix/custom.cfg;
fi
### END /etc/grub.d/41_custom ###
done
[root@AMULET4 grub2]# vi /boot/grub2/grubenv
# GRUB Environment Block
saved_entry=77365af69e5d472db85cf7355cc97ac2-4.18.0-553.32.1.el8_10.x86_64
kernelopts=root=UUID=85e9f883-4cb1-41c3-b5ff-41d68e37b2de ro crashkernel=auto resume=UUID=5d770573-28ef-469d-bbb9-686c6514cd33 rhgb quiet acpi=off
boot_success=1
boot_indeterminate=0
####################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################################
~
~
“grubenv” [noeol] 6L, 1024C
となり、反映されたようです。
しかし、やはり、「再起動」で、電源が落ちませんでした。
ということで、上記の設定は元に戻し、継続課題とすることにしました。うーむ。

コメント