linux中grub启动引导程序的加密介绍
作者:繁华似锦Fighting
1、什么是grub加密
上篇文章说了,系统在开机的时候,有一个5秒的读秒时间,方便你进入到grub
界面中。
如下图所示:
此时我们按下Enter键,就可以进入到grub
界面中。
如下图所示:
在选择框的正下方可以看到有几行提示:
# 使用 ↑ 和 ↓ 键高亮某个选项,并按回车键确认来引导选定的操作系统。 Use the ↑ and ↓ keys to select which entry is highlighted. Press enter to boot the selected OS, # 按e键在启动之前编辑命令, 'e' to edit the connands before booting, # 按a键在启动之前修改内核参数, 'a' to nodify the kernel argunents before booting, # 按c键切换命令行(esc键返回)。 or 'c' for a connand-1 ine.
可以看到提示,按e
键就能编辑grub
配置文件中的启动选项内容。
按e
键,结果如下图:
提示再按e
键可直接修改内容。
而grub
加密,就是在上面第二张图的状态时,需要先输入我们设定的密码,才能按e
键编辑系统启动参数。也就是说给grub
设置一个密码, 避免像上边那样能够直接进入grub
,并编辑其中的系统启动参数。
2、grub加密步骤
1)执行grub-md5-crypt
命令成生md5密码。
执行命令:[root@localhost ~]# grub-md5-crypt
2)设置密码。
输入两次密码:
Pas sword: Retype pas sword:
生成MD5加密的密码字符串:$1$Y84LB1$8tMY2PibScmu0Cc8z8U351
这样就把你输入的密码进行了MD5加密,用这个加密字符串来加密grub
配置文件。
3)修改grub的配置文件。
一定在timeout
属性之后,在splashimage
属性之前,添加password
选项,一定是这个顺序,放在其他位置不生效。
如下所示:
[root@localhost ~]# vim /boot/grub/grub.conf # 内容 default=0 timeout=5 # password选项放在整体设置处。 password --md5 $1$Y84LB1 $8tMY2PibScmu0Cc8z8U35/ splashimage=(hd 0,0)/grub/splash.xpm.gz
4)重启系统。
重启系统后,我们发现进入到grub
界面中,下面的提示,原来的e
键变成了p
键。
我们再按e
键都是没有反应的,按p
键就会让你输入密码,不输入密码你就不能编辑grub
的配置文件。
如下图所示:
输入后按Enter键,才进入到可编辑的grub
界面中,e
键提示又出来了。如下图:
注意:
当你在第四步中第一个图的时候,就算你不知道密码,直接按Enter键,系统是可以直接启动的。所以说grub
加密是对grub
配置文件的编译进行了加密,而不是对系统的启动进行加密。
上面的加密步骤,是对grub
菜单整体加密,整体加密后,如果想进入grub
编辑界面必须输入正确的密码。同时也是不影响系统的正常启动的。
还有对单个启动菜单进行加密,但grub
的编辑模式是不能锁定的,还是可以按e
键进入编辑模式。而且进入编辑模式后,是可以删除password
字段的,不是很好,所以不讲解了。
3、grub加密的lock属性
如果我想启动CentOS系统时,既需要grub
的整体加密,又需要系统启动时输入正确的grub
加密密码,才能正常启动系统。那应该怎么做呢?
很简单,方法如下:在grub
的/boot/grub/grub.conf
配置文件中,在title
字段中加入lock
,代表锁死,如果不输入正确的grub密码,系统是不能启动的。
如下图所示:
注意:
lock
这个属性千万不要添加,如果添加了lock
属性在grub
的配置文件中,当你在不输入密码的时候,直接按Enter键,是不能直接进入系统的,会报错,如下图:
提示了错误32,按任意键继续,就又回来了。
为什么一定不要添加lock
的原因:
在系统启动的时候,进入到grub
启动引导,此时系统还没有启动完成,网卡是还没加载生效,所以远程终端是连接不上服务器的,这时候就只能拿键盘做本地输入。但现在我们的服务器一般都放在机房或者远端,你会十分的不方便。所以坚决不能用lock
锁定grub
的配置文件。
到此这篇关于linux中grub启动引导程序的加密介绍的文章就介绍到这了,更多相关linux grub启动引导加密内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!