前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CentOS EFI引导问题修复

CentOS EFI引导问题修复

作者头像
腾讯云TStack
发布2019-10-18 09:40:13
11K0
发布2019-10-18 09:40:13
举报

本文作者 / 飞哥

专注于OpenStack计算、Python

热爱大海、雪山

导 言

UEFI正在逐渐取代传统的BIOS,在使用UEFI启动系统的过程中,有时会遇到系统无法启动的问题。如,制作好的centos虚拟机镜像与iso分离后竟无法启动?突然掉电导致引导文件丢失?怎样才能修复这些问题使得虚拟机能够正常工作?本篇描述了在openstack环境下一次引导文件丢失问题的修复过程。

一、问题描述

在一个openstack环境中,对几台虚拟机进行了resize操作,将内存有32G调整到了48G,磁盘和cpu均保持不动。其中有2个虚拟机出现了resize完成后无法启动的情况,通过虚拟机console界面可以看到虚拟机报如下错误信息:

从前面的输出可以看出,这是一个关于UEFI的问题,无法加载\EFI\neokylin\grubaa64.efi。

二、UEFI是什么

UEFI(Unified Extensible Firmware Interface, 统一的可扩展固件接口)是一种用来替代 BIOS 的标准,它一开始叫 EFI,后来统一之后改叫 UEFI。对于硬盘启动而言,UEFI 的作用之一是读取硬盘上的引导信息,然后加载。

UEFI固件会遍历磁盘上的每个EFI系统分区(按照磁盘上的分区顺序),固件将查找位于特定位置的具有特定名称的文件,即\EFI\BOOT\BOOT{计算机类型简称}.EFI。

对于x86_64平台来说,计算机类型简称为x64,所以这个默认的特定文件是\EFI\BOOT\BOOTx64.EFI;对于aarch64平台来说,计算机类型简称为AA64,所以这个默认的特定文件是\EFI\BOOT\BOOTAA64.EFI。

在安装CentOS操作系统的时候,系统会要求必须创建一个/boot/efi分区,否则系统无法引导启动,这个分区就是前面提及的EFI系统分区,这个分区里面存放了UEFI启动所需要的文件。下面通过一个具体的虚拟机来看下这个分区下的文件:

三、问题分析

现在再来看一下刚开始提到的系统启动失败的问题,从打印信息可知shim调用StartImage()发生了异常,原因是找不到\EFI\neokylin\grubaa64.efi文件。

首先进入正常的虚拟机,查看文件\EFI\neokylin\grubaa64.efi是否存在,文件的具体路径从前面可以知道是/boot/efi/EFI/neokylin/grubaa64.efi:

从上面的输出可以看到,正常虚拟机是有grubaa64.efi这个文件的。那么对于存在问题的虚拟机,猜测可能是该文件丢失导致的无法启动。

由于目前虚拟机已经无法正常启动,我们可以将虚拟机的磁盘挂载到正常的操作系统上来进行修复。这里我们将虚拟机的系统盘挂载到宿主机的目录下,进行查看和修改。要挂载虚拟机的磁盘文件到宿主机的文件系统中,需要使用到libguestfs-tools,安装方法如下:

代码语言:javascript
复制
[root@compute ~]# yum install -y libguestfs-tools

接下来使用guestmount命令将虚拟机的系统盘挂载到/mnt目录下:

从命令输出可以看到,当前这个有问题的虚拟机确实丢失了grubaa64.efi文件。

四、问题解决

知道具体的原因后,问题解决就变得很容易了,只需要从正常的虚拟机中将grubaa64.efi文件拷贝出来,并放到/mnt/boot/efi/EFI/neokylin目录下就可以完成虚拟机的修复。

执行完上面的操作后,虚拟机就可以正常启动了。

参考资料:

1、https://blog.woodelf.org/2014/05/28/uefi-boot-how-it-works.html

2、http://bbs.wuyou.net/forum.php?mod=viewthread&tid=303679

3、http://jcf94.com/2017/08/06/2017-08-06-efi/

4、https://access.redhat.com/documentation/zh-tw/red_hat_enterprise_linux/6/html/installation_guide/s2-grub-whatis-booting-uefi

5、http://blog.itpub.net/20747382/viewspace-2153053/

猜你还想看这些内容

●Harbor企业级实践丨20倍性能提升so easy!

●Harbor企业级实践丨零侵入改造!

Kustomize上篇丨Helm 和 Kustomize:不只是含谷量的区别

Kustomize下篇丨Kustomize 中的增删改查

· END ·

记得文末点个好看鸭~


点就完事儿了!

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-10-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 腾讯云TStack 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
专用宿主机
专用宿主机(CVM Dedicated Host,CDH)提供用户独享的物理服务器资源,满足您资源独享、资源物理隔离、安全、合规需求。专用宿主机搭载了腾讯云虚拟化系统,购买之后,您可在其上灵活创建、管理多个自定义规格的云服务器实例,自主规划物理资源的使用。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档