dracut 使用笔记
dracut 维基 https://dracut.wiki.kernel.org/index.php/Main_Page
dracut 官方手册 https://www.kernel.org/pub/linux/utils/boot/dracut/dracut.html#dracutkernel7
dracut 下载地址 https://www.kernel.org/pub/linux/utils/boot/dracut/
dracut是什么
关于这点网上能找到的翻译和介绍也不少,我就说说我的理解吧,dracut是用来制作initramfs的工具。这个initramfs是在系统启动前加载到内存中的一个临时文件系统。作用就是帮助我们正确引导系统,如果没有initramfs这个东东我们的系统是启动不了的。
其实编译内核的时候是会生成对应的initramfs文件的,在编译完内核,执行了make install之后就会在/boot/目录下生成以“initramfs”开头,以“.img”结尾的文件,中级内容一般是对应的版本号。如图:
既然编译内核能够生成initramfs文件,为什么还要用dracut再生成一次呢?
大概原因有二:一是内核太过庞大,重新编太过麻烦。另一个原因就是有时需要加一些定制化的东西,直接改内核要求太高,用dracut就方便许多了。
支持FakeRaid和软Raid
修改脚本
系统进入initramfs之后默认看不到raid分区的各个磁盘,需要执行命令
mdadm -As --auto=yes --run
后才能看到,我把这个命令加到了/lib/dracut/modules.d/90mdraid/parse-md.sh文件的最后。
如图:
parse-md.sh这个脚本是有一个触发钩子的,在/lib/dracut/modules.d/90mdraid/module-setup.sh中挂载:
pre-trigger可以理解为钩子的挂载点,具体有哪些挂载点,有代表什么位置,可以看看官方的帮助文档:dracut.modules(7) - Linux manual page
添加完命令,就可以生成文件了。
生成initramfs文件
不论是FakeRaid还是软Raid都要用到一个mdadm的工具,我编译好的initramfs是不带的,可以通过命令添加:
dracut --add "mdraid" /root/initramfs-raid.img 5.4.155 --force
- --add 后面是要添加的模块名称。
- initramfs-raid.img 是要生成的文件名。
- 5.4.155 是我内核的版本号,dracut会自动去/lib/modules/5.4.155下加载相关模块内容。版本号可以不写,默认是加载当前运行内核的版本。
- --force 是强制执行,如果已经有目标文件存在,则会覆盖该文件。
执行完成之后可以查看模块加载是否成功:
lsinitrd -m /root/initramfs-raid.img
- -m 为只显示模块名字,不加的话还会现在一大堆文件信息。
- initramfs-raid.img就只前面生成的initramfs文件。
支持LVM(逻辑卷)
修改脚本
和Raid类似,lvm一会有看不到分区的问题,需要在/lib/dracut/modules.d/90lvm/下创建脚本“pre-trigger-lvm.sh”,脚本的内容是两行命令
vgchange -a y
vgmknodes
这两行命令的作用在我的另一篇文章LVM踩坑总结中做了介绍。
在/lib/dracut/modules.d/90lvm/module-setup.sh中使用inst_hook挂载刚才创建的脚本。
inst_hook mount 30 "$moddir/pre-trigger-lvm.sh"
- mount同上面一样,也是钩子的挂载点。
生成initramfs文件
dracut --add "multipath lvm" initramfs-lvm.img 5.4.155 --force
用生成的initramfs替换掉/boot/下的文件,在系统启动的开始阶段就能够读到Raid和LVM分区了。
dracut 使用笔记相关推荐
- SRE运维工程师笔记-文件查找和压缩
SRE运维工程师笔记-文件查找和压缩 1. 文件查找 1.1 locate 1.2 find 1.2.1 指定搜索目录层级 1.2.2 对每个目录先处理目录内的文件,再处理目录本身 1.2.3 根据文 ...
- thinkpython2_python2 笔记
*************************************** [Python 应用笔记 THINKCORE] ************************************ ...
- 【读书笔记】知易行难,多实践
前言: 其实,我不喜欢看书,只是喜欢找答案,想通过专业的解答来解决我生活的困惑.所以,我听了很多书,也看了很多书,但看完书,没有很多的实践,导致我并不很深入在很多时候. 分享读书笔记: <高效1 ...
- 【运维学习笔记】生命不息,搞事开始。。。
001生命不息,搞事不止!!! 这段时间和hexesdesu搞了很多事情! 之前是机械硬盘和固态硬盘的测速,我就在那默默的看着他一个硬盘一个机械测来测去. 坐在他后面,每天都能看到这位萌萌的小男孩,各 ...
- SSAN 关系抽取 论文笔记
20210621 https://zhuanlan.zhihu.com/p/353183322 [KG笔记]八.文档级(Document Level)关系抽取任务 共指id嵌入一样 但是实体嵌入的时候 ...
- pandas以前笔记
# -*- coding: utf-8 -*- """ Created on Sat Jul 21 20:06:20 2018@author: heimi "& ...
- PyTorch 学习笔记(六):PyTorch hook 和关于 PyTorch backward 过程的理解 call
您的位置 首页 PyTorch 学习笔记系列 PyTorch 学习笔记(六):PyTorch hook 和关于 PyTorch backward 过程的理解 发布: 2017年8月4日 7,195阅读 ...
- 容器云原生DevOps学习笔记——第三期:从零搭建CI/CD系统标准化交付流程
暑期实习期间,所在的技术中台-效能研发团队规划设计并结合公司开源协同实现符合DevOps理念的研发工具平台,实现研发过程自动化.标准化: 实习期间对DevOps的理解一直懵懵懂懂,最近观看了阿里专家带 ...
- 容器云原生DevOps学习笔记——第二期:如何快速高质量的应用容器化迁移
暑期实习期间,所在的技术中台-效能研发团队规划设计并结合公司开源协同实现符合DevOps理念的研发工具平台,实现研发过程自动化.标准化: 实习期间对DevOps的理解一直懵懵懂懂,最近观看了阿里专家带 ...
最新文章
- ()shi linux字符设备,Linux字符设备驱动基础(三)
- 应用编排与管理:Job DaemonSet
- python123平台作业答案第十二周_【2018年 网鼎杯CTF 第二场】红日安全-网鼎杯WriteUp(24日 更新:web详解)...
- PHP中的PHP_EOL变量
- 【海洋女神原创】一个完整的Installshield安装程序实例—艾泽拉斯之海洋女神出品(二) --基本设置二...
- 深度学习术语_您应该意识到这些(通用)深度学习术语和术语
- 装箱与拆箱 c# 1613534570
- Java API 中文版 谷歌翻译 拿走不谢 jdk api 1.8_google
- android蓝牙软件,Android手机蓝牙助手(Bluetooth File Transfer)
- 使用JS访问本地数据库
- 解读Tilera怪兽级64核处理器(转)
- 【Vegas原创】“光驱无法访问,函数不正确”解决方法
- Illustrating How Mechanical Assemblies Work
- 云计算day12-Kubernetes_K8s
- GD32F303固件库开发(17)----内部Flash读写
- 野指针,数组指针,指针数组
- 计算机桌面颜色异常怎样修复,显示器颜色不正常如何调_电脑显示屏的颜色不对如何处理...
- qmcflac转flac的python实现
- 固态移动硬盘“函数不正确”
- 网银互联携手Aryaka,全托付方案亮相SD-WAN峰会