【问题标题】:i want read another kernel when an error occurs发生错误时我想读取另一个内核
【发布时间】:2018-03-29 19:54:27
【问题描述】:

读取内核时,我想在发生错误时读取另一个内核。 因为内核编译中的 ssh 远程。 grub 选项可以吗?

title CentOS (3.13.6)
        root (hd0,0)
        kernel /vmlinuz-3.13.6 ro root=/dev/mapper/vg_sizone-lv_root rd_NO_LUKS rd 
_LVM_LV=vg_sizone/lv_root rd_NO_MD crashkernel=auto LANG=ko_KR.UTF-8  KEYBOARDTYPE 
=pc KEYTABLE=ko rd_LVM_LV=vg_sizone/lv_swap rd_NO_DM rhgb quiet
        initrd /initramfs-3.13.6.img
title CentOS (2.6.32-642.6.1.el6.x86_64)
        root (hd0,0)
        kernel /vmlinuz-2.6.32-642.6.1.el6.x86_64 ro root=/dev/mapper/vg_sizone-lv 
_root rd_NO_LUKS rd_LVM_LV=vg_sizone/lv_root rd_NO_MD crashkernel=auto LANG=ko_KR. 
UTF-8  KEYBOARDTYPE=pc KEYTABLE=ko rd_LVM_LV=vg_sizone/lv_swap rd_NO_DM rhgb quiet
        initrd /initramfs-2.6.32-642.6.1.el6.x86_64.img

如果 3.13.6 内核崩溃。我要启动 2.6.32

【问题讨论】:

  • Stack Overflow 是一个编程和开发问题的网站。这个问题似乎离题了,因为它与编程或开发无关。请参阅帮助中心的What topics can I ask about here。也许Super UserUnix & Linux Stack Exchange 会是一个更好的提问地点。
  • 一旦内核崩溃,您不能选择忽略它而只加载另一个内核。根据恐慌的性质,此时的系统可能会变得无响应/无用。
  • 也许你可以让 GRUB 设置某种硬件看门狗计时器,如果 Linux 没有完全启动并“解除”它,它将重新启动机器。

标签: linux grub panic grub2


【解决方案1】:

这不可能在所有场景中都实现;但是,如果您想为您的服务器测试新内核并在不工作时回退到旧内核,您可以获得。

我假设您现在使用旧内核启动并想要测试新编译的内核。
为新内核创建菜单项后,请确保将 'panic=N' 添加到内核命令行参数;这将确保在内核崩溃 N 秒(如果 N 大于零)后重新启动。

那么,

将当前启动的内核设置为默认值:

# grub-set-default <current kernel menuentry number>
# grub-reboot <new kernel menuentry number>

这里注意菜单项编号从0开始。 然后,重新启动系统。

# reboot

这将引导到新编译的内核并重新引导到旧内核,以防内核崩溃。

【讨论】:

    【解决方案2】:

    总的来说,如果要启动一个新的 linux,需要注意内核映像、ramdisk 和 linux 驱动程序。

    我没有发现你的 grub 配置有什么问题,你为什么不试试呢?

    【讨论】:

    • 我尝试内核编译。内核恐慌是可怕的。如果 3.13.6 内核崩溃。我无法连接服务器。
    • 在你尝试编译内核之前,尝试用 2.6.32 启动,如果没问题,然后回到 linux 3.10 做你想做的事情。
    【解决方案3】:

    在前面添加一行:

    默认=1


    如果 default=0 ,则启动 3.13.6

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2018-08-18
      • 2022-01-10
      • 2018-04-26
      • 1970-01-01
      • 2021-03-30
      • 2019-12-16
      相关资源
      最近更新 更多