linux开机启动遇到grub启动_Linux启动之grub详解,故障排除,自建linux

本文深入探讨了Linux启动流程中的grub,包括grub的概念、故障排除方法,以及如何自建简单的Linux系统。内容涵盖grub的各阶段、功能、配置文件,以及针对grub启动故障的各种修复策略,旨在帮助读者理解和解决Linux启动问题。

概述

上篇我们以CentOS6为例介绍了一下系统启动流程,本篇将承接上篇,详细的介绍一下系统启动流程中的grub,以及系统启动过程中的各种故障的排除,以及利用现有内核自己构建一个能够正常启动的简单Linux系统。具体分为一下几个部分:

1、grub相关概念详解

2、系统启动故障排除

2.1  grub配置文件错误无法进入系统

2.2  grub的stage1故障修复

2.3  grub的stage1.5故障修复

2.4  grub的stage2故障修复(删除/boot/grub目录和内核vmlinuz文件,initramfs文件)

2.5  破坏grub的stage1、stage1.5、删除boot目录的故障恢复

2.6  破坏grub的stage1、stage1.5、删除boot目录,删除/etc/fstab文件的故障恢复

2.7  当系统安装在lvm逻辑卷上时, 破坏grub的stage1、stage1.5、删除boot目录,删除/etc/fstab文件的故障恢复

2.8  系统上init程序被破坏后的恢复,inittab文件被破坏后的恢复

3、自建Linux系统

第一章    grub相关概念详解

1、linux上bootloader之grub详解:

grub 0.X: centos5、6上用的,也称之为grub legacy

grub 1.X: centos7上用的,也称之为grub2

2、grub legacy:分为几个阶段

stage1:安装在MBR中前446字节中

stage1_5:MBR之后的扇区,主要是让stage1中的bootloader能识别stage2所在的分区上的文件系统,否则无法加载stage2阶段

stage2:存放在磁盘分区上,一般在/boot/grub/目录下,这才是真正实现开机时显示的菜单和相关功能的程序所在位置,改程序也有其配置文件,配置文件时/boot/grub/grub.conf,其有个软链接文件是/etc/grub.conf

stage2及内核等,通常放置于一个基本磁盘分区,而不应该是放在lvm、软raid分区等复杂分区上,因为grub不能驱动lvm、软raid分区,另外lvm、软raid的识别是系统初始化脚本/etc/rc.d/rc.sysinit的功能,该功能在内核启动之后,init接管的时候才实现。

3、grub的功能:

<1>提供菜单,并提供交互式接口

e:编辑模式,用于编辑菜单

c:命令模式,交互式接口

等等

<2>加载用户选择的内核或操作系统

并允许用户传递参数给内核

也支持隐藏菜单

<3>为菜单提供了保护机制

为编辑菜单进行认证

为启用内核或操作系统进行认证

4、grub中是如何识别设备

无论是什么接口的硬盘,都识别为hd

且用(hd数字1,数字2)表示第数字1的磁盘上的数字2的分区,都从0开始编号

故(hd0,0) 表示第1个磁盘上的第1个分区

5、grub的命令行接口:

help:获取帮助列表

help 关键字   可获取某个关键字的详细帮助信息

find (hd数字1,数字2)/FILENAME   可在指定磁盘设备上找指定的文件,判断文件的存在性

如:find (hd0,0)/vmlinuz

root (hd数字1,数字2)  表示将那个磁盘设备设置为grub的根设备,注意,这里的根并不是文件系统的根

如:root (hd0,0)

如果指定了根,在find时就可以不必指定设备,而直接从grub的根开始找对应的文件

kernel /PATH/TO/KERNEL_FILE   设定本次启动时用到的内核文件,一般都需要用root指定grub根之后才指定kernel,额外还可以添加许多内核支持使用的命令行参数,如:

init=/PATH/TO/INIT  指定init程序

selinux=0   表示禁用内核中的selinux功能

root=/DEVICE   表示指定真正根文件系统所在的设备

max_loop=#   表示指定最大的loop设备的个数

initrd /PATH/TO/INITRAMFS_FILE   为选定的内核提供额外文件的ramdisk文件,ramdisk文件必须与内核版本号必须完全匹配

boot   引导启动选定的内核

6、grub的配置文件 /boot/grub/grub.conf或/etc/grub.conf

定义了启动时进入grub后哪个显示出来的可供用户选择的菜单,如果没有该定义,就要通过grub的命令行界面进行手工引导启动

配置文件内容为:

default=0  设定默认启动的菜单项,菜单项(title)编号从0开始

timeout=5  指定菜单项等待选项选择的超时时长

splashimage=(hd0,0)/grub/splash.xpm.gz  指明菜单背景图片文件路径

hiddenmenu   是否隐藏菜单

password [–md5]  STRING  表示设定菜单编辑认证,也就是启用grub时,用e键编辑时,需要进行认证的密码,加上–md5 就表示利用md5进行加密

title CentOS 6 (2.6.32-642.el6.x86_64)   定义菜单项的标题,并用tab缩进定义该菜单项下的各个属性信息,可出现多次,用来引导多个不同的内核或操作系统

root (hd0,0)    本菜单项的查找statge2及kernel文件所在的设备分区,为grub的根,不是文件系统的根

kernel /vmlinuz-2.6.32-642.el6.x86_64 ro root=UUID=20a69d3d-34c6-436d-b7fc-fb110f65649f rd_NO_LUKS  KEYBOARDTYPE=pc KEYTABLE=us rd_NO_MD crashkernel=auto.UTF-8 rd_NO_LVM rd_NO_DM rhgb quiet     指明启动的内核及相关内核参数

initrd /initramfs-2.6.32-642.el6.x86_64.img     内核匹配的ramdisk文件

password [–md5] STRING   启动选定的内核或操作系统时进行认证

grub-md5-crypt命令可以生成grub里面认证密码的md5码

7、grub-install命令

grub-install命令可以实现对grub的安装修复,能够修复grub的stage1,stage1.5,stage2的相关内容,但是其不能修复stage2中grub的配置文件

用法为:grub-install /磁盘设备号  –root-directory=/PATH

指明为哪个磁盘安装grub,以及该磁盘上的文件系统的根所在的路径,如果是命令本身所在的shell的文件系统根,则–root-directory可以省略

第二章    系统启动故障排除

1、grub配置文件写错,无法进入系统

步骤:(修复完成后记得修改配置文件为正确的文件)

方法一:进入启动菜单项后,修改菜单项为正确的内容,然后启动

方法二:进入启动菜单后,进入grub交互式界面,手动引导启动

2、grub的stage1故障修复

步骤:

<1>破坏grub的stage1,如果未重启,则直接利用grub-install命令进行修复,如果重启,则继续

<2>重启后发现无法进入系统,此时可以利用光盘进入紧急救援模式,然后进行grub-install安装修复

3、grub的stage1.5故障修复

步骤:

<1>破坏grub的1.5阶段,重启系统(如果没重启,可直接用grub-install进行安装)

<2>进入紧急救援模式(进入救援模式的步骤省略),进行grub-install安装修复grub

4、grub的stage2故障修复(删除/boot/grub目录和内核文件,ramdisk文件)

步骤:

<1>删除/boot/grub目录和内核文件vmlinuz,ramdisk文件initramfs,然后重启

(如果没重启,可以直接拷贝系统光盘上的vmlinuz文件,然后运行mkinitrd命令生成initramfs文件,然后运行grub-install命令生成修复grub文件,最后编辑grub配置文件即可)

<2>进入紧急救援模式(进入过程省略)进行修复

5、破坏grub的stage1、stage1.5、删除boot目录的故障恢复

步骤:

<1>破坏stage1、stage1.5,删除boot目录,然后重启

如果没重启,rpm安装kernel包(注意加上–replacepkgs或–force选项,因为kernel安装的文件不仅仅有boot目录下的相关文件,如果不用选项,会报错),然后grub-install安装修复grub,然后编辑生成一个grub.conf配置文件即可

<2>进入紧急救援模式(进入紧急救援模式的过程省略),修复

6、破坏grub的stage1、stage1.5、删除boot目录,删除/etc/fstab文件的故障恢复

步骤:

<1>破坏grub的stage1、stage1.5、删除boot目录,删除/etc/fstab文件,重启系统

如果破坏后,尚未重启系统,只需重新编辑/etc/fstab文件,然后与上个实验一样,安装kernel包(注意加–replacepkgs或–force选项),grub-install安装grub,然后提供grub的配置文件即可

<2>进入紧急救援模式,进行修复

7、当系统安装在lvm逻辑卷上时, 破坏grub的stage1、stage1.5、删除boot目录,删除/etc/fstab文件的故障恢复

步骤:

<1>破坏stage1、stage1.5,删除boot目录、删除/etc/fstab文件,并重启

<2>进入紧急救援模式修复

8、系统上init文件、inittab文件破坏后的恢复方案

步骤: 思路为查询文件是由哪个程序生成,然后在救援模式下进行安装对应的包,进行修复

第三章    自建Linux系统

实验环境:

CentOS6.8的64位系统

思路为:在现有虚拟机上添加一个新磁盘,然后对磁盘做出相关操作,然后新建一个虚拟机,新建的虚拟机利用该块磁盘完成系统启动

步骤:

1、在原有虚拟机上添加一块磁盘

2、对添加的磁盘进行分区,格式化

3、挂载新建的磁盘分区

4、拷贝内核文件、ramdisk文件到新磁盘的boot目录,为新磁盘创建grub,提供grub配置文件

5、为新磁盘的根添加相关的目录结构,并拷贝相关程序及程序依赖的库文件到新磁盘上

6、新建虚拟机,并将虚拟机的磁盘指向到我们做好的磁盘

7、启动虚拟机,验证功能

8、复制命令用到的脚本为:

[root@localhost ~]# cat scripts/course/copycmd.sh

#!/bin/bash

# Autor: nwc

# Version: 2.0

# CreateTime:

function CMDCP() {

DIR=`dirname $CmdPath`

if [ -d ${LuJing}${DIR} ] ;then

cp $CmdPath ${LuJing}${DIR} && echo "cp $CMD success" || echo "cp $CMD fail"

else

mkdir -p ${LuJing}${DIR}

cp $CmdPath ${LuJing}${DIR} && echo "cp $CMD success" || echo "cp $CMD fail"

fi

}

function CMDLIBCP() {

for i in ${LibCmd} ; do

LIBDIR=`dirname $i`

if [ -d ${LuJing}${LIBDIR} ];then

cp $i ${LuJing}${LIBDIR} && echo "cp $i success" || echo "cp $i fail"

else

mkdir -p ${LuJing}${LIBDIR}

cp $i ${LuJing}${LIBDIR} && echo "cp $i success" || echo "cp $i fail"

fi

done

}

while true;do

read -p "Input a exec program name like ls/cat... q for quit  " CMD

case $CMD in

q)

echo "exit..."

exit

;;

*)

if which --skip-alias $CMD &>/dev/null  && [[ $CMD != "q" ]]; then

CmdPath=`which --skip-alias $CMD`

LibCmd=`ldd $CmdPath|grep -o -E "/[^[:space:]]+"`

LuJing=/mnt/sys

CMDCP

CMDLIBCP

else

echo "you input is not a right command"

continue

fi

;;

esac

done

原创文章,作者:M20-1倪文超,如若转载,请注明出处:http://www.178linux.com/45876

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值