centos6.9启动之grub

本文主要介绍系统启动中grub部分

grub介绍:

grub是引导操作系统的程序,它会根据自己的配置文件,去引导内核,当内核被加载到内存以后,内核会根据grub配置文件中的配置,找到根分区所使用的问件系统对应的驱动,通过根分区文件系统 对应的驱动,挂载根分区,从而达到启动操作系统的目的。

centos5/6中使用grub作为bootloader,也就是说,操作系统想要启动,就要靠它,早期的linux中,使用LILO(linux loader)进行操作系统的引导工作,但是因为LILO的功能比较简单,随着发展,出现了grub,  GRUB:Grand Unified Bootloader

centos5\6中使用的是grub的0.97版本:grub legacy

centos7中使用的是grub2

此处,我们讨论的grub就是grub legacy

 

grub legacy的3个阶段:

Grub stage 1(MBR前 446 个字节)要进入grub 2 阶段(/boot/grub/目录下),要先获取boot分区文件系统驱动模块,于是有了1.5阶段(MBR 后面的 27 个扇区),存放boot分区所需要的文件系统驱动模块

Grub stage 1(MBR前 446 字节)作用:找到grub stage 1.5阶段并将其加载到内存中

↓↓

Grub stage 1.5(MBR 后面的27扇区,存放boot分区所需要的文件系统驱动模块)

↓↓

Grub stage 2(/boot/grub/目录下文件)

 

grub安装:

  • (1) grub-install (推荐用法,修复grub全阶段)

安装grub stage1和 stage1_5到/dev/DISK磁盘上,并复制GRUB相关文件到 DIR/boot目录下

grub-install –root-directory=DIR /dev/DISK

  • (2) grub (限制较多,依赖于/boot/grub/下文件,文件破坏则不能使用)

grub> root (hd#,#) (hd#,#是指/boot/所在磁盘分区)

grub> setup (hd#)     (安装在哪个磁盘)

 

配置文件:

  • /boot/grub/grub.conf <– /etc/grub.conf
  • stage2及内核等通常放置于一个基本磁盘分区

功用:

(1) 提供启动菜单、并提供交互式接口

a:编辑内核参数

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

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

(2) 加载用户选择的内核或操作系统

允许传递参数给内核

可隐藏启动菜单

(3) 为菜单提供了保护机制

为编辑启动菜单进行认证

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

 

  • 识别硬盘设备

(hd#,#)

hd#: 磁盘编号,用数字表示;从0开始编号表示第一个

#: 分区编号,用数字表示; 从0开始编号表示第一个

例如:(hd0,0) 第一块硬盘,第一个分区

 

  • 手动在grub命令行接口启动系统

grub> kernel (hd0,0)/vmlinuz-VERSION-RELEASE ro root=/dev/DEVICE

grub> initrd (hd0,0)/initramfs-VERSION-RELEASE.img

grub> boot

 

  • 配置文件:/boot/grub/grub.conf

如下图:

博客

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

②timeout=#:指定菜单项等待选项选择的时长

splashimage=(hd#,#)/PATH/XPM_FILE:菜单背景图片文件路径

(默认无)password [–md5] STRING: 启动菜单编辑认证

⑤hiddenmenu:隐藏菜单

⑥title TITLE:定义菜单项“标题”, 可出现多次

⑦root (hd#,#):查找stage2及kernel文件所在设备分区;为grub的根!!!

⑧kernel /PATH/TO/VMLINUZ_FILE [PARAMETERS]:启动的内核

⑨initrd /PATH/TO/INITRAMFS_FILE: 内核匹配的ramfs文件

(默认无)password [–md5|–encrypted ] STRING: 启动选定的内核或操作系统时进行认证

 

选项注解:自制启动菜单背景:先下载ImageMagick工具;

取640×480尺寸的图片如win.jpg ;

将图片格式转为xpm的:convert -resize 640×480 -colors 14 win.jpg win.xpm

打包gzip win.xpm

然后将图片移到/boot/grub/目录下;

修改grub.conf文件选项文件路径即可。

选项注解:加密口令字符串STRING是用 grub-md5-crypt 交互式命令(md5加密方式)或 grub-crypt 交互式命令(sha512加密方式)生成

 

破解root口令:

启动系统时,设置其运行级别1(即单用户模式)

进入单用户模式:

(1) 编辑grub菜单(选定要编辑的title,而后使用e命令)

(2) 在选定的kernel后附加 : 1, s, Ssingle都可以

(3) 启动:在kernel所在行,键入“b”命令

 

实验:

一、/dev/sda前面的446字符清零,(grub1阶段)

  1. 开机自动进入光盘引导模式,有备份直接拷贝过来;
  2. 无备份,先切根,再grub-install /dev/sda 即可修复,sync同步磁盘(多来几遍),防止数据没有同步。

二、(grub2阶段)

  1. /boot/grub/下的除了grub.conf文件和图片压缩文件,别的都删掉,系统不受影响照常启动,再用grub交互式修复文件,失败(报找不到文件),
  2. /boot/grub/下的除了grub.conf文件和图片压缩文件,别的文件如果通过grub交互式命令修复过一次,再删掉,系统重启就会报错卡住无法正常重启,修复方法同“实验一”

三、/dev/sda  512字符后面的字符破坏(grub1.5阶段)

开机进度条界面完了之后卡在黑屏界面,修复方法同“实验一”

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/98394

(4)
上一篇 2018-05-13 16:39
下一篇 2018-05-13 17:48

相关推荐

  • Linux系统中RAID及LVM管理

    Linux系统中如何提高磁盘的读写性能,如何实现磁盘冗余,当磁盘快被占满时,又如何弹性拓展磁盘容量,RAID及LVM技术可以帮你轻松解决。

    2018-04-26
  • rpm以及yum基础

    第四周

    Linux笔记 2018-04-22
  • yum

    yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器。基於RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软体包,无须繁琐地一次次下载、安装。yum提供了查找、安装、删除某一个、一组甚至全部软件包的命令,而…

    2018-04-20
  • sed的用法

    sed是一种流编辑器,它一次处理一行内容。 处理时,把当前处理的行存储在临时缓冲区(pattern space),同时输出到屏幕,接着用sed命令处理缓冲区中的内容,接着读取下一行,这样不断重复,直到文件末尾。 用法: sed -[options] [操作] inputfile -n:不输出模式空间内容到屏幕,即不自动打印 -e: 多点编辑 -f:/PATH…

    2018-04-22
  • liunx 基础

    命令别名: 命令格式 :

    Linux笔记 2018-04-01