initramfs及rpm/dracut操作

2024-05-08 02:36
文章标签 操作 initramfs rpm dracut

本文主要是介绍initramfs及rpm/dracut操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、背景

更新bundle包后发现系统异常。

定位发现驱动升级不成功,内核启动后加载的还是更新前的旧驱动。但等内核启动完成后,卸载旧驱动手动insmod新驱动,是可以加载成功的。

驱动的安装目录在/lib/modules/$KERNELVERSION/extra目录下。

最终定位为,问题机器"更新"过内核,而且是强行安装了同一个版本的内核RPM包。导致原来机器上的驱动被打包到了initramfs中,即使后续更新驱动,内核启动的时候始终加载的是initramfs中的旧驱动。

二、initramfs如何生成?

initramfs是打包到内核安装包里,然后安装到/boot目录下的么?

1、获取rpm包的安装文件

extract内核安装rpm包的内容,看到内核安装包里只有三个目录,boot和lib和sbin。

而boot目录下是config文件、符号表、vmlinuz。所以,内核安装包只涉及内核源码和编译相关的vmlinuz/符号表/config文件。

#rpm2cpio kernel_5.10.0-3.0.0.3.rpm | cpio -ivdm
#ls
kernel-5.10.0-3.0.0.3.x86_64.rpm  boot  lib  sbin
#cd boot/
#ls
config-5.10.0-3.0.0.3  System.map-5.10.0-3.0.0.3  vmlinuz-5.10.0-3.0.0.3

initramfs和根文件系统的镜像文件属于操作系统的范畴,不会在内核安装包里,那他们是怎么生成的呢?它们是在执行内核rpm包安装的时候,根据当前机器上的操作系统环境生成的!!!

2、获取rpm包的spec文件

我们看一下内核rpm包的spec文件,试图查找一下initramfs的蛛丝马迹。

首先比较确认的是,spec文件并不会直接打包到rpm包里,所以无法直接获取,可以尝试使用rpmrebuild命令“重新生成/还原”一个相似的spec文件。

https://stackoverflow.com/questions/5613954/extract-the-spec-file-from-rpm-package

命令如下:

#rpmrebuild --package --notest-install -e oracle-instantclient-basic-10.2.0.4-1.x86_64.rpm
#rpmrebuild -s hercules.spec hercules

第二条命令我没有执行成功,但执行第一条命令的时候会弹出 spec文件的编辑界面。此时可以查看spec文件的内容,生成initramfs的命令如下。

if [ -e /sbin/new-kernel-pkg ]; then/sbin/new-kernel-pkg -v --depmod --install 5.10.0-3.0.0.3 --kernel-args=crashkernel=384M --make-default --dracut --mkinitrd >> /boot/install.log 2>&1
else/bin/kernel-install add 5.10.0-3.0.0.3 /boot/vmlinuz-5.10.0-3.0.0.3 >> /boot/install.log 2>&1 || exit 0
fi

所以安装内核的时候是通过/sbin/new-kernel-pkg生成rootfs和initramfs的,new-kernel-pkg内部调用/usr/bin/dracut生成initramfs。

而且内核的安装日志都会记录在/boot/install.log中。

3、解压initramfs镜像

解压initramfs镜像:

http://node01.linuxcoming.com/index.php/archives/33/

可以使用如下命令解压initramfs镜像:

# cd /tmp/initramfs
# /usr/lib/dracut/skipcpio initramfs-3.10.0-229.el7.x86_64.img | zcat | cpio -ivd

有专门的lsinitrd命令,可以用它查看initramfs中的文件列表:

#lsinitrd /boot/initramfs-5.10.0-3.0.0.3.img

lsinitrd命令使用还是很方便的。

三、dracut配置选项

之前如何解决的问题呢,将/lib/modules/'uname -r'/extra目录下的驱动手动删除掉,然后重新安装一下内核rpm包,这样新打包的initramfs就不会带有我们自己的驱动了。

但这种方式始终没有从根本上解决问题,因为没有办法确保大家都不会更新相同版本的内核,只要有人又执行了这些操作,就会出现相同的问题。

如果可以配置哪些文件不被打包进initramfs中,这才是合理的解决问题的方式。

有一个linuxconfig的官方网页,有一篇文章对如何使用dracut生成根文件系统进行了详细说明。

How to build an initramfs using Dracut on Linux - Linux Tutorials - Learn Linux Configuration

通过上面的文章找到了答案,dracut.conf配置其omit_drivers参数,即可规避某些文件的打包。

dracut.conf(5) - Linux manual page

omit_drivers+="driver_0 driver_1"

这篇关于initramfs及rpm/dracut操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/969061

相关文章

动手学深度学习【数据操作+数据预处理】

import osos.makedirs(os.path.join('.', 'data'), exist_ok=True)data_file = os.path.join('.', 'data', 'house_tiny.csv')with open(data_file, 'w') as f:f.write('NumRooms,Alley,Price\n') # 列名f.write('NA

线程的四种操作

所属专栏:Java学习        1. 线程的开启 start和run的区别: run:描述了线程要执行的任务,也可以称为线程的入口 start:调用系统函数,真正的在系统内核中创建线程(创建PCB,加入到链表中),此处的start会根据不同的系统,分别调用不同的api,创建好之后的线程,再单独去执行run(所以说,start的本质是调用系统api,系统的api

Java IO 操作——个人理解

之前一直Java的IO操作一知半解。今天看到一个便文章觉得很有道理( 原文章),记录一下。 首先,理解Java的IO操作到底操作的什么内容,过程又是怎么样子。          数据来源的操作: 来源有文件,网络数据。使用File类和Sockets等。这里操作的是数据本身,1,0结构。    File file = new File("path");   字

MySQL——表操作

目录 一、创建表 二、查看表 2.1 查看表中某成员的数据 2.2 查看整个表中的表成员 2.3 查看创建表时的句柄 三、修改表 alter 3.1 重命名 rename 3.2 新增一列 add 3.3 更改列属性 modify 3.4 更改列名称 change 3.5 删除某列 上一篇博客介绍了库的操作,接下来来看一下表的相关操作。 一、创建表 create

封装MySQL操作时Where条件语句的组织

在对数据库进行封装的过程中,条件语句应该是相对难以处理的,毕竟条件语句太过于多样性。 条件语句大致分为以下几种: 1、单一条件,比如:where id = 1; 2、多个条件,相互间关系统一。比如:where id > 10 and age > 20 and score < 60; 3、多个条件,相互间关系不统一。比如:where (id > 10 OR age > 20) AND sco

PHP7扩展开发之流操作

前言 啥是流操作?简单来讲就是对一些文件,网络的IO操作。PHP已经把这些IO操作,封装成流操作。这节,我们将使用PHP扩展实现一个目录遍历的功能。PHP示例代码如下: <?phpfunction list_dir($dir) {if (is_dir($dir) === false) {return;} $dh = opendir($dir);if ($dh == false) {ret

浙大数据结构:树的定义与操作

四种遍历 #include<iostream>#include<queue>using namespace std;typedef struct treenode *BinTree;typedef BinTree position;typedef int ElementType;struct treenode{ElementType data;BinTree left;BinTre

浙大数据结构:04-树7 二叉搜索树的操作集

这道题答案都在PPT上,所以先学会再写的话并不难。 1、BinTree Insert( BinTree BST, ElementType X ) 递归实现,小就进左子树,大就进右子树。 为空就新建结点插入。 BinTree Insert( BinTree BST, ElementType X ){if(!BST){BST=(BinTree)malloc(sizeof(struct TNo

hibernate修改数据库已有的对象【简化操作】

陈科肇 直接上代码: /*** 更新新的数据并并未修改旧的数据* @param oldEntity 数据库存在的实体* @param newEntity 更改后的实体* @throws IllegalAccessException * @throws IllegalArgumentException */public void updateNew(T oldEntity,T newEntity

mysql中导入txt文件数据的操作指令

1 表tt的格式:    CREATE TABLE `tt` (   `ind` int NOT NULL auto_increment,   `name` char(100) default NULL,   PRIMARY KEY  (`ind`)  )   2 文件d.txt的内容示例:  1,a  2,b  3,c