设为首页 收藏本站
查看: 869|回复: 0

[经验分享] centos7grub配置文件及排错

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-9-2 09:21:26 | 显示全部楼层 |阅读模式
RHEL7用了grub2,而不再是grub了
  MBR分区的前446个字节存放的是系统引导程序grub,中间64字节是分区表,最后2个字节表示结束。那么什么是grub是怎么工作的呢?
  简单的说,开机会经历以下几步:
  1、BIOS自检,检查硬件;
  2、激活MBR,MBR上不存在文件系统,可以视作硬件一部分,因此可以被直接读取
  3、grub加载到内存,生成一个微系统,微系统内置了精简版的文件系统
  4、通过这个微系统,他会去引导分区,比如默认一般是sda1上去找内核文件如vmlinuz,然后再调用grub的配置文件。
  grub的主要把他的配置文件放在了3个地方。
  /boot/grub2/grub.cfg  (/etc/grub2.cfg是/boot/grub2/grub.cfg文件的符号链接)
  /etc/grub.d/  
  /etc/default/grub
  如下所示。他们的关系是 grub.cfg里面通过 ####BEGIN  ##### 这种格式按照顺序调用/etc/grub.d里面的脚本实现不同的功能。grub.d目录里面有很多数字开头的脚本,按照从小到大的顺序执行。以00__header为例,他又会调用 /etc/default/grub 配置文件来实现最基本的开机界面配置
   wKiom1fHxFSwbIXvAAArp5OKHF4216.jpg
  例如:在/etc/grub2.cfg是文件里面调用 /etc/grub.d/10_linux 来配置不同的内核,这里面有2个 menuentry (菜单入口),所以我们开机的时候会看见两个默认选项,一个是普通模式,一个是救援模式
   wKiom1fHxFTy0_GhAACdBxQAyUo471.jpg
  这个是/etc/default/grub 文件。和其他的脚本比较起来,非常简单直观了。后面会举例如何修改
  需要注意的是,最好不要直接去修改 /etc/grub2.cfg 文件。这个是因为如果后期升级内核,所有的配置都会失效。如果需要自定义这个文件,我们可以修改对应的脚本或者 /etc/default/grub文件,然后通过 grub2-mkconfig 重新生成grub.cfg文件。
  例1:修改启动的等待时间
  rhel7默认启动等待时间为5秒,下面将启动时间修改为3秒(注:如果改为-1,那么每次启动时需手动确认才可以)
  修改/etc/default/grub文件,如下图所示:
   wKiom1fHxFXCjlnTAAA1-wOR0x0804.jpg
  修改之后重新编译生成grub.cfg文件
   wKioL1fHxFbwIIBnAABC--TJFWk361.jpg
  例2:修改网卡的显示名字,这个前面做网络配置的时候提到过,这里不赘述了。
  例3:加密grub
  开机界面的时候如果输入e,会打开编辑窗口,我们可以根据需要进入rescue, emergency 或者 shell 模式。如何限制访问。
  在/etc/grub.d/00_header 文件末尾,添加以下内容
   wKiom1fHxFbyLMbsAAAtK8cnmws439.jpg
  重新编译生成grub.cfg文件
   wKioL1fHxFey2rwUAAA4Lhvwn0o552.jpg
  重启之后输入e,就需要用户和密码才能进入编辑窗口了
  以上设置的是明文密码,那如何设置密文口令呢?
  加密密码由命令grub2-mkpasswd-pbkdf2生成
   wKioL1fHxFej7RlDAAAZFscV7JY942.jpg
  在/etc/grub.d/00_header 文件末尾,添加以下内容
  cat <<EOF
  set superusers=’用户名’
  password_pbkdf2 用户名加密密码
  EOF
  如下图所示:
   wKioL1fHxFiSPQjXAAAjYsVq16E502.jpg
  重新编译生成grub.cfg文件
  grub2-mkconfig–o /boot/grub2/grub.cfg
  重启验证
  注:在文本终端模式下,安装并启用gpm后就可复制粘贴了。
   wKioL1fHxFnDbfKgAAAuL9eJ9lQ268.jpg
  在这个编辑窗口,我们可以根据需要进入 rescue,emergency和 shell引导的3种模式。这3种模式对于系统启动排错很有帮助,比如某个服务卡住了无法加载我们可以通过这3种模式来排错。
  rescue模式: 在commandline的配置末尾添加s ,类似rhel6之前的单用户模式
   wKiom1fHxFriQsDVAAA0qFT5h1c267.jpg
  按ctrl+x启动
  普通模式需要加载的服务很多,但是这个rescue模式加载的就少很多了,输入管理员密码就可以进入了。
   wKioL1fHxFqSfW3PAAB7uzo_eOk426.jpg
  emergency 模式和rescue模式类似,不过加载的服务更少,把s改成 emergency就行了
  那么如果忘记root密码了怎么办?
  方法1:
  1、重启系统,按e
  2、在linux16那行的最尾部加上一下信息
  rd.break console=tty0
   wKiom1fHxFvRG3szAAAtomzCd7I840.jpg
  3、按ctrl+x启动
  4、重新挂在文件系统
   wKioL1fHxFzhNYpsAAAWy7TlJ44794.jpg
  5、改变根目录
   wKioL1fHxFyA16W7AAAftaboFgw254.jpg
  6、修改root密码
   wKiom1fHxF3TmM5dAAA1RDFq1CQ472.jpg
  7、在根目录下创建相关文件(用于重新标记selinux环境值)
   wKioL1fHxF2T_cUHAAAbO1klpGQ298.jpg
  8、退出,系统将会重启
   wKiom1fHxF6BusbKAAAr5uXbNY0139.jpg
  方法2:
  在linux16 的最后一行删除 rhgb quiet, 然后添加 init=/bin/sh, 他会用shell替代默认的daemon进程
   wKiom1fHxF6CNNFJAAAoGWAM93I805.jpg
  按ctrl+x启动
  挂载文件系统为可写模式,原因很简单,根目录加载的权限是ro,只读,重新加载成 rw的权限。
   wKioL1fHxF_AzeToAAAVyttzy50225.jpg
  这个时候就可以修改密码了,执行passwd,按提示修改root密码
   wKiom1fHxF-yLkE1AAA-_jbG-Ng314.jpg
  如何之前系统启用了selinux,必须运行以下命令,否则将无法正常启动系统:
   wKioL1fHxGDxkGIoAAA5EmQrZ5M042.jpg
  创建这个文件会自动在开启的时候重新做标签即用于重新标记 SELINUX 环境值
  运行命令exec /sbin/init来正常启动,或者用命令exec /sbin/reboot重启
  注意:红帽考试时建议使用方法1,方法2在考试环境中以过时了。
  开机排错
  例1. grub故障:比如把MBR的前446个字节都覆盖了。
   wKiom1fHxGHwZI1jAAAuBabMsiA465.jpg
  系统重启后则出现如下故障现象
  开机的时候会自动尝试从本地,光盘和网络加载引导程序(如果光盘、网络等引导失败则会operatiing system not found);这里是从我的光盘加载的,因为本地的引导程序已经没有了.
   wKioL1fHxGGAGW8AAAA5ASS9gMo100.jpg
  选择troubleshooting (排错)
   wKiom1fHxGLSVIMmAAA1JaSdrRQ090.jpg
  选择resure a red hat enterprise linux system
   wKiom1fHxGOBKL0dAABW3SggiIs007.jpg
  选择continue,注意有耐心多等一下,有的时候会卡个10秒才有反应
  按照提示,切换根到本机的系统
   wKiom1fHxGTho0UZAABt9UjEYPg073.jpg
  fdisk -l 看看启动分区是哪个,有星号的就是
   wKiom1fHxGWjhw9fAAAhPhdqNzo804.jpg
  重装一下 grub2 到启动分区就可以了
   wKioL1fHxGWinOdfAAAlte0N4lE728.jpg
  重启就OK了
  例2:如果grub引导程序没问题,但是我们把内核文件或者grub.cfg配置文件给删除了怎么办
   wKiom1fHxGajIj6KAABQs0509tQ695.jpg
  重启之后,直接进入grub的救援模式,这表明引导程序木有问题,但是引导文件找不到了
   wKiom1fHxGbw5CMEAAAcChcJ5sk343.jpg
  和前面一样,光盘启动,切换根目录,挂载一下光盘到光盘挂载点, 顺便看看/boot目录,里面空荡荡的,内核文件和配置文件都没了
   wKiom1fHxGehZAqRAAAmZJSn4VY206.jpg
  解决方法就是重新安装内核,可以用rpm 或者yum,用yum需要先卸载当前的,再安装; rpm可以强行--force覆盖安装。
   wKiom1fHxGjjFlprAAAniF8wqRw453.jpg
  装完内核之后,重新安装一次 grub2, 输入 grub2-install /dev/sda, 然后重新编译一下grub2就行了
   wKioL1fHxGiCkrySAABG3afiAyQ480.jpg
  重启系统就可以了。
  重启之后,如果遇见以下问题:
  问题是开机直接进入命令行模式,即使runlevel显示的是5,手动输入startx一样报错。
  解决方式是重新安装图形化界面
  yum grouplist
  yum groupinstall 'Server with GUI'


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-266468-1-1.html 上篇帖子: linux 下 pdf 转换成txt 下篇帖子: cetos7网络链路聚合 配置文件
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表