Linux GRUB legacy

Linux GRUB

Linux GRUB

GRUB简介

了解grub之前,需要理解linux的启动流程,如果之前有对linux启动流程不了解的可以看:http://xinzong.blog.51cto.com/10018904/1757337

GRUB(GRand Unified Bootloader)统一引导加载器,即启动加载器。centos上的grub分为两个版本,分别是:
 centos 7默认采用grub2

GRUB legacy(GRUB 0.1一般称为grub1)
   GRUB 2(grub1.0一般称为grub2)
   本文主要以grub legacy展开介绍

GRUB 菜单组成

GRUB菜单

介绍菜单之前,先带大家了解一下grub legacy
grub legacy分为三个阶段:

stage 1:mbr
 stage1_5:mbr之后的扇区,作用是让stage1中的bootloader能识别stage2所在分区上的文件系统
 stage2:磁盘分区()/boot/grub/)

stage2及内核等通常放置于一个基本磁盘分区。
 stage2的功用:

1、提供菜单、并提供交互式接口
   e:编辑模式,用于编辑菜单
   c:命令模式,交互式接口
   2、加载用户选择的内核或操作系统
   允许传递参数给内核
   可隐藏此菜单
   3、为菜单提供了保护机制
   为编辑菜单进行认证
   未启用内核或操作系统进行认证

GRUB命令行接口

grub1.png

grub2.png

grub的命令行接口:

help: 获取帮助列表
 help KEYWORD: 详细帮助信息
 find (hd#,#)/PATH/TO/SOMEFILE:查找文件
 root (hd#,#)
 kernel /PATH/TO/KERNEL_FILE:设定本次启动时用到的内核文件;额外还可以添加许多内核支持使用的cmdline参数;
     例如:init=/path/to/init, selinux=0
 initrd /PATH/TO/INITRAMFS_FILE: 设定为选定内核提供额外文件的ramdisk;
 boot: 引导启动选定的内核;

手动在grub命令行接口启动系统:
grub> root (hd#,#)
grub> kernel /vmlinuz-VERSION-RELEASE ro root=/dev/DEVICE  
grub> initrd /initramfs-VERSION-RELEASE.img
grub> boot

grub3.gif

GRUB配置文件

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

default=#: 设定默认启动的菜单项;菜单项(title)编号从0开始;
 timeout=#:指定菜单项等待选项选择的时长;
 splashimage=指明菜单背景图片路径(hd#,#)/PATH/TO/XPM_PIC_FILE)
 hiddenmenu:隐藏菜单;
 password [–md5] STRING: 菜单编辑认证;
 title TITLE:定义菜单项“标题”, 可出现多次;

root (hd#,#):grub查找stage2及kernel文件所在设备分区;为grub的“根”;  
   kernel:启动的内核
   initrd 内核匹配的ramfs文件;
   password [–md5] STRING: 启动选定的内核或操作系统时进行认证;
   加密密码可以使用:
   grub-md5-crypt命令

GRUB安装及修复

  • 安装修复:grub-install

实例

注意:–root-directory必须指定boot所在的上一级目录

#mount /dev/sdb1 /mnt/boot
#grub-install --root-directory=/mnt /dev/sdb2
Probing devices to guess BIOS drives. This may take a long time.
/dev/mapper/vg_centos6-lv_root does not have any corresponding BIOS drive.
# ls /mnt/boot/
grub
# ls /mnt/boot/grub/
device.map     ffs_stage1_5      minix_stage1_5     stage2           xfs_stage1_5
e2fs_stage1_5  iso9660_stage1_5  reiserfs_stage1_5  ufs2_stage1_5
fat_stage1_5   jfs_stage1_5      stage1             vstafs_stage1_5
  • 安装修复:grub命令

# grub
Probing devices to guess BIOS drives. This may take a long time.


   GNU GRUB  version 0.97  (640K lower / 3072K upper memory)

[ Minimal BASH-like line editing is supported.  For the first word, TAB
  lists possible command completions.  Anywhere else TAB lists the possible
  completions of a device/filename.]
grub> root (hd1,0)
root (hd1,0)
Filesystem type is ext2fs, partition type 0x83
grub> setup (hd1)
setup (hd1)
Checking if "/boot/grub/stage1" exists... no
Checking if "/grub/stage1" exists... yes
Checking if "/grub/stage2" exists... yes
Checking if "/grub/e2fs_stage1_5" exists... yes
Running "embed /grub/e2fs_stage1_5 (hd1)"...  27 sectors are embedded.
succeeded
Running "install /grub/stage1 (hd1) (hd1)1+27 p (hd1,0)/grub/stage2 /grub/grub.conf"... succeeded
Done.

GRUB单用户及救援模式

单用户模式(密码破解)

进入单用户模式:
(1) 编辑grub菜单(选定要编辑的title,而后使用e命令);  
(2) 在选定的kernel后附加
1, s, S或single都可以;
(3) 在kernel所在行,键入“b”命令;

grub4.gif

救援模式

grub修复
1、模拟破坏:(破坏前先备份)

dd if=/dev/sda of=/root/mbr.bak count=1 bs=512
dd if=/dev/zero of=/dev/sda count=1 bs=200

2、进入救援模式

grub5.png

1、插入光盘进入救援模式
-方式1:点击Rescue installed system
方式2:按esc进入命令行
输入 linux rescue
2、选择语言,键盘类型
3、选择是否使用语言
4、是否将当前系统的跟挂载至/mnt/sysimage下
Continue:继续
5、选择OK # 可以使用chroot /mnt/sysimage
6、选择shell start shell
7、切换跟,修复grub

# chroot /mnt/sysimage
# grub-install --root-directory=/ /dev/sda
# exit
# reboot

8、重启前拆除光盘
图解

grub6.gif

对于grub就写到这里了,感觉写的不错可以给点个赞。 
 作者:Ace QQ1257465991 Linux运维攻城狮一只 
 Q/A:如有问题请慷慨提出

原创文章,作者:Ace,如若转载,请注明出处:http://www.178linux.com/15249

(0)
AceAce
上一篇 2016-04-25 21:15
下一篇 2016-04-25 21:22

相关推荐

  • linux时间设置、screen使用、命令分类、hash作用、命令引用及history命令

    一、 生产环境发现一台服务器系统时间产生偏差,造成服务异常 解决方法             a、 如果服务器硬件时间准备的话,可使用命令:~#] hwclock -s              将硬件时钟同步到系统 &…

    Linux干货 2013-06-11
  • 推荐-常用RAID级别详解

    一、RAID是什么       RAID(Redundant Arrays of Indent Disks)的名称是独立磁盘冗余阵列,是一种通过将多块硬盘按照某种特定的结构组织起来当做一块硬盘来使用的技术,多块硬盘不同的组织结构我们称之为RAID的级别。而RAID技术的特性主要表现在两个方面: (1)提高硬盘…

    Linux干货 2016-03-27
  • 用户和组的相关配置文件

      用户,是计算机识别使用者身份的一种唯一使用标识。 而现实生活中为了方便人类记忆使用等,用户名往往是用便于人类识别的语言来记录的。但事实上计算机并不对人类语言敏感,所以有必要把人类语言跟机器语言对应上。于是,linux给每一个创建用户提供了一个UID。当使用用户名登录时,系统换自动对应UID来识别该用户身份。 而用户名与UID的对应信息就储存在一…

    Linux干货 2016-10-23
  • 使用CDN后,PHP如何获取用户的真是IP?

    在统计访问日志参数的时候IP是一个重要的参数,所有索取客户端的IP就至关重要。 在logformat配置中有两个变量是获取IP地址的: remoteaddr:客户端IP xforwardedfor:客户端的IP 从上面来看两个都是客户端IP,那这两个变量有什么不同? 首先当你访问某个网站,假设你中间不经过任何代理,那么webserver就会把remotead…

    Linux干货 2015-12-21
  • Linux的发展史

       在早期电气化发展时代1946年诞生了计算机事物,早期的计算机体积巨大,只能适用于一个人操作,而且运行速度慢。但已经形成计算机的架构体系,为了尽可能的榨干计算机资源在计算机发展的二阶段,于是有当时著名实验室BELL ,GE,MIT共同研发了一款叫MULTCS操作系统,这也是最早的操作系统。   1946年一个没有完成的梦想,…

    Linux干货 2016-10-13
  • linux中用ACL实现灵活的权限管理

    ACL是什么?? ACL英文原意是Access Control List(访问控制列表).它能够实现灵活的权限管理,除了文件的所有者,所属组和其他人,设置相应的权限外,ACL允许你给任何用户或是用户组设置任何文件/目录的访问权限(注意的是有些不支持数字模式的权限给定) ACL有什么用?? 作为UGO权限管理的补充,acl有GUO办不到或者是难以办到的功能 &…

    Linux干货 2016-08-05