GRUB管理

对于运维人员来说,想要熟练掌握linux,那么久要对linux的启动流程有一个详细的了解,而今天我们就一起来学习一下linux启动中最重要的一个阶段——GRUB引导阶段。

Linux启动流程

GRUB管理

grup: GRand Unified Bootloader 

由上图可知,grub属于系统启动过程中一个必须的阶段。而这个阶段又分为了三个小的阶段,分别是stage1,stage1.5,stage2。

stage1: mbr 磁盘的前446字节

>这个内容被破坏会自动进入光盘启动界面,因为机器认为没有了硬盘启动功能

stage1_5: mbr之后的扇区512字节后的内容,让stage1中的bootloader 能识别stage2所在的分区上的文件系统 

>这个内容被破坏系统读条会黑屏,不会自动出现光盘引导。因为1阶段已经启动,机器认为可以在硬盘启动,但是读入硬盘后无法通过1.5阶段进入2阶段

stage2:在磁盘的boot分区中(/boot/grub/grup.conf),

>只是grub.conf文件损坏,出现grub>提示符。grub目录如果被误删,会出现error15,并且黑屏,无法启动

grub的命令行接口

在系统启动的内核选择界面,可以选择进入命令行接口。

GRUB管理
>解释:
>e:进入编辑模式 编辑菜单 可通过这个模式进入单用户

>a:修改内核参数 例如关闭selinux

GRUB管理

>c:进入grub命令行模式 交互式接口

grub的stage2配置文件

grub第二阶段的是三个阶段中唯一可以直接以可读文件形式展现给我们的阶段。它最重要的配置文件就是/boot/grub/grub.conf <– /etc/grub.conf(后面这个是软连接)。如下图:
GRUB管理

对配置文件的解释:

注释:

这个文件是由安装向导anaconda生成的。对该文件进行修改后,不需要重复运行,因为或者文件是开机自动读取的。注意:若你有一个boot目录的独立分区,这意味着所有的内核和伪根路径都是相对于这个boot目录的路径来设置的。

这里的/代表的不是我们操作系统的根,因为root(hd0,0)表示的是指的我们的第一磁盘的第一分区,也就是boot所在分区,他们以boot为根(就算不写root(hd0,0)也可以,因为默认就是这个)。因此可以写成以下格式:
root (hd0,0) 
kernel /vmlinuz-version ro root=/dev/sda2
initrd /initrd-[generic-]version.img

但如果/boot不是一个独立分区,而是在根这个分区中,则需要加上/boot的路径,如:
kernel /boot/vmlinuz-version ro root=/dev/sda2
initrd /boot/initrd-[generic-]version.img

内容:

default=#: 设定默认启动的菜单项;落单项(title)编号从0开始。因为可以配置多个内核,所以有多个系统可供选择。 

timeout=#:指定菜单项等待选项选择的时长 ,如果不写,需要手动敲回车才能进入系统。

splashimage=(hd#,#)/PATH/XPM_FILE:菜单背景图片文件路径 ,这个是可以更改的。选择内核时的背景图片。这个是可以更改的,但是有格式要求。

hiddenmenu:隐藏菜单 ,写了这个就不会出现自动出现系统选择界面,而需要敲任意键才会出现。

password [–md5] STRING: 启动菜单编辑认证 。可以在这个项目增加密码,这样可以让用户只有输入密码才能进入内核编辑界面,而且可以对密码进行加密。

title TITLE:定义菜单项“标题”, 可出现多次 ,这个比较随意。
root (hd#,#):hd#: 磁盘编号,用数字表示;从0开始编号 #: 分区编号,用数字表示; 从0开始编号 (hd0,0)表示根在 第一块硬盘,第一个分区 查找stage2及kernel文件所在设备分区

kernel /PATH/TO/VMLINUZ_FILE [PARAMETERS]:启动的内核 。在起后面有很多内容都是内核参数,都是内核中的默认功能,可以进行修改或关闭。后面有一项rhgb是开启启动动画(转圈圈那个-.-),开启的话会不显示启动的各种字符的过程,不利于排错,建议删除关闭。有一项是quit默认隐藏内核启动过程,可以删除让其关闭。可以用cat /proc/cmdline来查看开启了那些内核参数。在/grub.conf文件中也可以看到。
ro root=UUID=a6c8e0e3-2fa0-4e9f-bd90-4 指定根的目录。是内核的一个参数

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

password [–md5|–encrypted ] STRING: 启动选定的内核或操作 系统时进行认证 在这个条目增加密码

grub的安装和修复命令

grub是一个命令,有着自己的语法结构,如下图:
GRUB管理

通过grub.conf文件为linux加密

为进入编辑模式进行加密

通过编辑模式可以进入单用户模式,直接修改root口令,因此可以通过对进入单用户模式加密,从而增强linux的安全性。
GRUB管理
进入到系统选择画面,可以看到已经没有了常用的e选项,只剩下了p选项
GRUB管理
输入p后需要输入密码才能进入编辑模式,而这个密码就是我们在grub.conf文件中写入哪个密码。

为加载linux系统进行加密

对于是否让系统启动,我们也可以有权进行管理。通过下图的方法,我们可以对系统启动进行密码保护,更加加强了linux的保密性。
GRUB管理
这个加载在救援模式之后,系统启动之前
GRUB管理

利用加密算法设置口令

上面两个密码的设置都是明文,如果别人在开机后查看grub.conf文件是可以看到的。因此可以同过加密算法来设置口令。

例如:通过md5加密

进入vim的命令模式输入 grub-md5-crypt
password –md5 加密口令
GRUB管理

例如:通过sha算法加密

进入vim的命令模式输入grub-crypt 输入两边口令自动加密,并将加密结果写入 password –encrypted 加密口令
GRUB管理
>如果上面的口令全部忘记,可以通过救援模式,直接修改文件即可。
因此可以看出,只要物理能接触服务器或者主机,所有的保密将不复存在。

修改背景菜单图片

对于我们的linux内核选择界面的背景图片,我们也可以自己进行设置,将图片jpg,png格式都可以。具体方法如下:

将图片在linux中进行处理,使用工具convert。包为ImageMagick。

格式处理:convert -resize 640×480 -colors 14 picturename.jpg  picturename.xpm
GRUB管理
进行压缩:gzip picturename.xpm

移动到/boot/grub目录: mv picturename.xpm.gz  /boot/grub

修改配置文件,指定路径 splashimage=(hd0,0)/grub/picturename.xpm.gz

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

(1)
OscaoChaserOscaoChaser
上一篇 2017-09-02 20:36
下一篇 2017-09-02 20:39

相关推荐

  • 条件判断(if,case)和循环(for,until,while等)详解(附例题正解)

    脚本中的if条件判断和循环 在linux下,写脚本是我们必不可少的。在写脚本的过程中,if判断和各种的循环是我们常用的。这里,详细的说一下条件判断以及循环的使用。 条件判断:if 和 else 1.if shell程序中的条件分支是通过if条件语句来实现的,其格式一般为if -then -fi ,这样的是单分支语句,还有的一种就是if-then-else-f…

    Linux干货 2016-08-18
  • shell脚本总结

    shell进阶:列表生成方式:列表生成方式:(1) 直接给出列表 以空白为间隔(2) 整数列表:(a) {start..end}(b) $(seq [start [step]] end)(3) 返回列表的命令$(COMMAND)(4) 使用glob,如:.sh(5) 变量引用;$@, $while read line(用法)(用于遍历文件,进行处理…

    Linux干货 2017-07-10
  • Linux系统启动流程简介

    centos系统启动流程 本篇仅仅讲解centos5和6 centos7并不适用 Linux系统的组成部分:内核+根文件系统 内核功能: 进程管理 内存管理 网络管理 驱动程序 文件系统 安全功能 有以下目录结构的文件系统可以被识别为根文件系统,但根文件系统本身不存在 rootfs:/bin/ /sbin /etc/ /sys/…

    Linux干货 2016-09-10
  • 如何在微软Azure云机上添加新磁盘

    大家好: 最近在项目实践中,分享下如何在微软Azure云机上添加新磁盘。 首先需要查看下是否有未用上的磁盘,先fdisk -l查(看下图)并和Azure技术确认该磁盘是否可永久保存数据: 然后找到未分区的磁盘号,如上图中的/dev/sdc,再 fdisk /dev/sdc后开始在该新磁盘上进行分区创建: 为方便管理,我们一般就创建一个分区,然后进行格式化: …

    Linux干货 2016-11-27
  • Linux用户和组管理

    使用对象:Linux初学者   Linux系统中用户和组管理是很重要的一部分内容。许多初学者在学习或刚接触到用户管理的时候会觉得很难理解,命令多、选项多、配置文件也多,用命令可以修改,用配置文件也可以修改,三两下就被绕进去了。其实完全没必要晕,只要了解了用户管理的方式,就会很容易理解命令选项与配置文件之间的关系。下面我们就来了解下用户管理命令与配置…

    Linux干货 2016-10-23
  • 什么是CA??

       数字证书认证机构(英语:Certificate Authority,缩写为CA),也称为电子商务认证中心、电子商务认证授权机构,是负责发放和管理数字证书的权威机构,并作为电子商务交易中受信任的第三方,承担公钥体系中公钥的合法性检验的责任。 介绍     CA中心为每个使用公开密钥的用户发放一个…

    Linux干货 2017-07-17