Linux GRUB

12 篇文章 0 订阅
  • Linux 系统启动过程

    上电 --> BIOS 自检 --> 执行引导加载程序(grub) --> 加载内核(kernel) -->  执行 init 进程 --> 登录 Linux 系统

  • GRUB 启动过程
    Stage1 --> Stage1.5 --> Stage2


    BIOS 执行 INT 0x19 ,加载 MBR 至 0x7c00,(通常 GRUB 会安装到 MBR,MBR参考http://blog.csdn.net/u011641885/article/details/50358825),进入 Stage1 阶段(对应 /boot/grub/stage1 文件),stage1只负责做引导的动作,,为后面的步骤做铺垫工作。然后进入 Stage1.5 阶段(对应 /boot/grub/XXX_stage1_5 文件, XXX 指某一种文件系统)其作用是连接 stage1 到 stage2 的一个通道,里面唯一存放的是该系统文件的格式,这阶段的过程可以让 GRUB 在 stage1 启动完成后, stage2 能在被搬移后的情况下,就算不在原本的目录或文件系统中,依然可以被安全的找到。因为 stage1.5 被加载时,就已经赋予 GRUB 读取文件系统目录的能力,所以可以在找不到 stage2 的情况下,从文件目录中,找到 stage2 的所在位置。通常 stage1.5 阶段的文件不会放在目录中,因为当 stage1 还没加载 stage1.5 时,原则上是不能识别文件系统的,当然也找不到 stage1.5 这个文件。所以, stage1.5 是存在硬盘最前面的 32KB 的区段中(需要跳过MBR),当 stage1 调用 stage1.5 时,直接去该区域将 stage1.5 找出来使用。Stage2阶段(对应 /boot/grub/stage2 文件),该文件是 GRUB 的核心程序,能让用户以菜单方式将操作系统加载、新增参数、修改选项,这些全都是 stage2 的功能。对 GRUB 来说,stage2 除了不能自己启动外,剩下的事情全部都是由stage2完成。stage2 会读取 menu.lst 文件。

  • GRUB 阶段造成系统启动失败的问题及修复
    stage1 被破坏示例:(试验环境,RHEL6.4)
    在命令行执行
    dd if=/dev/zero of=/dev/sda bs=200 count=1 skip=1		# 写入到 MBR 的 201 - 400 字节,也就是 stage1 的 201 - 400 字节置零
    然后重启机器,会提示 PXE-E53:No boot filename received 和 PXE-M0F:Operating System not found ,如图:

    解决方法:
    使用光盘系统进入救援模式:进入系统安装的欢迎界面,按两下 Esc 键,然后在输入 linux rescue。进入救援模式,选择语言、键盘、修复的介质、是否启动网络后会看到提示硬盘的 根目录会挂载到 /mnt/sysimage 目录,如图:

    然后选择 shell ,如图:

    进入 shell 命令行后,可以运行 mount 命令确认 硬盘的根分区 是否被挂载到 /mnt/sysimage 如图:

    然后切换工作的根目录:
    chroot /mnt/sysimage
    安装 stage1
    grub-install /dev/sda
    补充:有时会因为软盘的原因出错,需要更新 device.map 文件,使用如下命令安装:
    grub-install --recheck /dev/sda  # 参数recheck是指,将BIOS中盘符信息与文件同步
    sync<span style="white-space:pre">			</span>         # 强制将内存中的文件缓冲内容写到磁盘<span style="white-space:pre">			</span>
    重启系统。

    stage2 被破坏实例:
    删除 stage2 文件,后重启机器,如图:

    重复 stage1 的解决方法即可。

    grub.conf 文件丢失实例:
    移除 grub.conf 文件
    mv grub.conf grub.conf.bak 
    重启机器,会进入 GURB 命令行模式。输入下列几行命令:
    root (hd0,0)	# 指定/boot 所在的分区, hd0 表示第一个硬盘,0表示第一个分区
    kernel /vmlinuz-2.6.32-358.el6.x86_64 root=/dev/sda2	#指定 linux 的内核,以及根所在的分区,根分区路径,要根据 /etc/fstab 文件而定 
    initrd /initramfs-2.6.32-358.el6.x86_64.img # 指定 initrd 文件
    boot	# 引导系统
    以上的几条命令可以临时解决进入系统的问题,如果需要永久解决的话,需要重新编写 grub.conf 文件。

    内核文件丢失实例:
    移除内核文件
    mv /boot/vmlinuz-2.6.32-358.el6.x86_64 /boot/vmlinuz-2.6.32-358.el6.x86_64.bak
    重启系统之后,在GRUB引导成功后,选择内核失败,如图:


    这个时候还是使用系统光盘进入救援模式的shell命令行,在命令行中输入以下命令:
    mkdir /rhel_iso							# 创建挂载点,挂载光盘镜像					
    mount -t iso9660 /dev/sr0 /rhel_iso		#挂载光盘镜像
    cd /rhel_iso/Packages					#进入 rpm 包所在目录
    rpm -ivh --root /mnt/sysimage --force  kernel-2.6.32-358.el6.x86_64.rpm  #安装keenel --root 指定根目录。(以 /mnt/sysimage 作为根文件系统进行操作) --force 覆盖原有文件强制安装
    重新系统发现 /boot 下有两个内核文件,如图:


     
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值