Rocky Linxuでシステム再起動しても電源が落ちない問題

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

となり、反映されたようです。

しかし、やはり、「再起動」で、電源が落ちませんでした。
ということで、上記の設定は元に戻し、継続課題とすることにしました。うーむ。

Linux、Netatalk、Samba、NFSを使用したファイルサーバーについて研究・運用しています。

fsをフォローする
課題ログ

コメント