前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >如何定制Linux外围文件系统?

如何定制Linux外围文件系统?

原创
作者头像
我是乖宝宝哦
修改于 2019-11-26 08:25:37
修改于 2019-11-26 08:25:37
5.4K00
代码可运行
举报
文章被收录于专栏:前端之心前端之心
运行总次数:0
代码可运行

一般来说,我们所说的Linux系统指的是各种基于Linux KernelGNU Project的操作系统发行版。为了掌握Linux操作系统的使用,了解 Linux操作系统的运作过程,理解内核与外围支撑系统的关系,加深对开源操作系统的认识,我决定造个轮子——自己定制一个Linux文件系统

这里有两种实现方法:

  • 直接自己实现init(M1)

加载bios 的硬件信息-> 读取MBR –>执行Grub ->加载kernel–> 加载驱动–> init –> 执行bash

  • 利用系统/sbin/init(M2)

加载bios 的硬件信息-> 读取MBR –>执行Grub ->加载kernel–> 加载驱动–> init –> /sbin/init -> 取得run-level信息 -> /etc/rc.d/rc.sysinit -> services –> /etc/rc.d/rc.local –> mingetty –> login

我们先选择M1

思路

  1. 利用原有系统复制必备部件到新存储器
  2. 利用initrd.img机制在RAM Disk中测试
  3. 搭配原文件内核和模块启动

Step1:获得shell版本的initrd.img

首先,我们可以写一个脚本init,使得内核用该文件系统启动后能够直接获得一个Bash

创建脚本 init
创建脚本 init

其中:/bin目录下是常用命令,init是自己写的脚本,/lib64目录下是应用程序所依赖的动态库。

init 内容
init 内容

现在我们需要使用命令行,创建binsbin目录,向其中添加bashlsrmcpmvechocatless等基础命令。由于这些命令需要依赖/lib64等目录下的一些动态链接的共享库,所以需要将依赖的库拷贝到小系统对应的目录下,用ldd命令查询应用程序及其依赖的动态库。完成之后,执行:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
find . | cpio -H newc -o | gzip > /boot/initrd.img

将根文件系统打包成initrd.img放到/boot目录下。启动时系统会自动执行initrd.img中的init

费了这么大劲生成initrd.img,如何测试新建的initrd.img呢,需要在grub启动配置文件当中增加一个入口用于测试。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
title CentOS 6 Mini
root (hd0,0)
kernel /vmlinuz-2.6.32-642.el6.x86_64
initrd /initrd.img

这样重启之后就会出现启动选项了。

Step2:完成挂载原系统能力

为了能挂载原系统,必须在initrd.img中加载原系统运行所必须的驱动模块,比如ext4文件系统的驱动、scsi设备的相关驱动等,/sbin/modinfo 配合/sbin/insmod,驱动放到/module

Step3:完成拥有管理设备能力(udev)

利用管理、监控主机设备的服务程序udevd来自动加载所需的驱动模块,比我们自己实现更加可靠。udevd的规则文件在/lib/udev/目录下,配置文件在/etc/udev/目录下,同时还需要/etc/nsswitch.conf配置的名称服务交换,其依赖的库为/lib目录下以libnss开头的文件,将上述文件拷贝到我们的目录下,然后使用/sbin/start\_udev命令可以启动udevd服务。(udevd需要调用一些其他的系统命令,如/sbin/modprobe,可用strace进行跟踪获取)。

小系统的目录文件
小系统的目录文件

其中:/dev目录下是系统存放可用设备的目录,/log是使用strace命令生成的log记录文件。

Step4:完成拥有login登录能力

由于login的机制比较复杂,涉及进程管理机制和进程组、控制台等许多方面,因此我们采用M2,将/sbin/init命令拷到小系统目录下,init脚本改为

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#!/bin/bash
exec /sbin/init

将控制权交给/sbin/init之后,系统启动时就必须等到它完成一系列调用之后,进入login界面,用户才能重新获得控制权。

/sbin/init的过程大致分为三块:第一块是udevd加载驱动模块、文件系统检查和根切换,相关配置在/etc/rc.sysinit中;第二块是启动各项服务,相关配置在/etc/rc.d/目录下;第三块是登录部分,需要调用/sbin/mingetty/bin/login等命令。将上述所涉及的命令及文件拷贝到小系统对应的目录下,并对配置进行修改。

由于小系统启动之后initrd.img作为临时根文件系统直接在内存中运行,而我们小系统不需要进行根切换,故将/etc/rc.sysinitremount\_needed()函数体注释掉,这样就不会根切换了。

由于系统采用了全新的Upstart启动方式(/sbin/init程序已经改由upstart软件包提供),将与Upstart启动相关的配置文件拷贝至小系统目录下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/etc/inittab 配置默认运行级别
/etc/init/rcS.conf 加载rc.sysinit脚本,完成系统初始化任务
/etc/init/rc.conf 兼容脚本,负责各运行级别的调用处理
/etc/init/rcS-sulogin.conf 为单用户模式启动/sbin/sushell环境
/etc/init/control-alt-delete.conf 控制终端下的Ctrl+Alt+Del热键操作
/etc/init/start-ttys.conf 配置tty终端的开启数量、设备文件
/etc/sysconfig/init 控制tty终端的开启数量、终端颜色方案
/etc/init/tty.conf 控制tty终端的开启

bootmini/etc/inittab的运行优先级改为2,那么系统启动时/sbin/init将执行bootmini/etc/rc.d/rc2.d/目录下以S开头的文件,将一些不需要开启的服务文件名改为K开头。

bootmini/etc/rc.d/rc.local文件中可以加入用户需要系统开机启动后自动执行的操作。

login程序基于认证体系PAM, 配置文件在/etc/pam.d/目录下,相关库文件有/lib64/security/及其依赖的库文件;login还涉及用户组管理/bin/chgrp/bin/chown/bin/chmod等,保存用户名的文件/etc/passwd/etc/group,用户密码文件为/etc/shadow。其他一些涉及的文件可通过strace来帮助分析。

可在真机上运行的完整版小系统

部分目录文件:

/etc
/etc
/bin
/bin
/sbin
/sbin
/usr/bin
/usr/bin
/usr/sbin
/usr/sbin

至此,文件系统算是可以跑了。下一篇我们再造个轮子——进行Linux内核的裁剪。真机效果也将在下篇看到。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

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

评论
登录后参与评论
暂无评论
推荐阅读
【数据库09】数据库系统体系结构
最早的数据库是在单台支持多任务的物理机器上运行的,这种集中式的数据库系统仍然在被广泛使用,如今在集中式数据库系统上运行的企业级应用可能拥有成千上万的用户,数据库的规模从兆字节到数百G字节不等。
半旧518
2022/11/22
6950
【数据库09】数据库系统体系结构
【数据库07】后端开发必备的大数据知识指南
随着计算机的飞速发展,网站产生了大量数据,数据规模远超传统数据库系统能够处理的规模,我们把具有量大,存储速度要求高,数据多样性丰富的特征的数据统称为大数据。
半旧518
2022/11/18
5540
【数据库07】后端开发必备的大数据知识指南
并行数据库技术分析与展望
本文以我个人的理解简单分析下并行数据库的技术要点以及对未来并行数据库的发展做下展望,理解有偏差的地方,欢迎各位指正。 并行数据库的定义 在维基百科上,并行数据库被定义为通过并行使用多个CPU和磁盘来将诸如装载数据、建立索引、执行查询等操作并行化以提升性能的数据库系统。其中最重要的关键词是并行,分布式。 并行数据库的技术要点‍ ‍ 并行数据库主要由执行引擎、存储引擎和管理功能模块组成,它们的不同技术风格形成了各个有特色的并行数据库产品。随着Hadoop的兴起,目前MPP数据库主要分成两类
大数据和云计算技术
2018/03/08
2.2K0
【数据库】01——精通数据库需要掌握这九个维度
数据库管理系统就是由互相关联的数据集合和一组用于访问这些数据的程序组成,简称数据库。即,数据库=数据+程序。数据库的目标就是方便、高效、安全的存储、管理数据信息。
半旧518
2022/10/26
4570
【数据库】01——精通数据库需要掌握这九个维度
数据库架构比较
20世纪90年代,使用MPP架构的Netezza和Teradata的数据库设备对Oracle,IBM和Microsoft在anlytics数据库市场的主导地位提出了挑战,并且随着“大数据”的出现以及带有分布式处理的Hadoop的严峻考验。
February
2018/12/10
4.2K0
数据库技术的发展
(1)第一代数据库系统是指层次模型数据库系统(基于树形结构)和网状模型数据库系统(基于有向图结构)
ellipse
2019/08/16
9470
史上最全分布式数据库概述
墨墨导读:在集中式数据库系统不能完全符合实际需要的形势下,集中式DB的“集中计算”概念向“分布计算”概念发展。分布计算主要体现在客户机/服务器模式的分布式数据库体系结构两个方面。
数据和云
2019/06/18
6.9K0
史上最全分布式数据库概述
【赵渝强老师】达梦数据库MPP集群的架构
为了支持海量数据存储和处理等方面的需求,为高端数据仓库提供解决方案,达梦数据库提供了大规模并行处理MPP架构,以极低的成本代价,提供高性能的并行计算。通过使用MPP可以解决以下问题:
赵渝强老师
2025/03/21
1740
【赵渝强老师】达梦数据库MPP集群的架构
[每天五分钟,备战架构师-10]数据库系统
事务是数据库系统运行的基本工作单位,相当于操作系统中的进程,事务具有ACID特性。从用户的角度来看,事务中的操作要么都做,要么都不做。
大江小浪
2018/09/19
1.6K0
系统分析师考试高频考试知识点
分布式数据库是由一组数据组成的,这组数据分布在计算机网络的不同计算机上,网络中的每个节点具有独立处理的能力(称为场地自治),它可以执行局部应用,同时,每个节点也能通过网络通信子系统执行全局应用。分布式数据库系统是在集中式数据库技术的基础上发展起来的,具体有如下特点:
小马哥学JAVA
2023/07/15
2270
系统分析师考试高频考试知识点
其他数据库系统
DB2数据库系统DB2是IBM公司开发的关系型数据库系统,他有很多版本,如DB2工作版、DB2企业版、DB2个人版、DB2企业扩展版,其区别在于是否支持远程客户能力和分布式处理能力。
ellipse
2019/08/16
1.3K0
Fourinone如何实现并行计算和数据库引擎
彭渊,在Java技术领域从业十多年,曾撰写多款开源软件,历任淘宝高级专家和华为中间件首席架构师。开源代表作有Fourinone(四不像)分布式核心技术框架、CoolHash并行数据库引擎等,曾出版书籍《大规模分布式系统架构与设计实战》。 以下为作者分享的整理: 前言:“如何用70行java代码实现深度神经网络算法”一文发表后,反响非常好,为此非常感谢CSDN架构编辑钱曙光先生和机器学习编辑周建丁先生对中国原创技术实践的支持,并接受邀请,就各位朋友感兴趣的分布式核心技术Fourinone(四不像)和高性能
CSDN技术头条
2018/02/11
1.4K0
Fourinone如何实现并行计算和数据库引擎
服务器体系(SMP, NUMA, MPP)与共享存储器架构(UMA和NUMA)
各CPU共享相同的物理内存,每个 CPU访问内存中的任何地址所需时间是相同的,因此SMP也被称为一致存储器访问结构(UMA:Uniform Memory Access)
233333
2018/12/14
5.2K0
服务器体系(SMP, NUMA, MPP)与共享存储器架构(UMA和NUMA)
分布式存储
分布式存储的思想是将数据分散存储在多个节点上,以提高数据的可靠性、可扩展性和性能。它基于以下几个核心思想:
明志德道
2023/12/18
5170
数据库查询优化技术(一):数据库与关系代数
我是看李海翔的《数据库技术丛书·数据库查询优化器的艺术:原理解析与SQL性能优化》这本书的视频讲解学习的,因为数据库的知识学的不多,直接看优化有些吃力,慢慢补吧。现在要用一些优化的知识只能先看着了。
sunonzj
2022/06/21
8600
数据库查询优化技术(一):数据库与关系代数
数据库技术发展与非关系型数据库NoSQL:
近几年来,NoSQL运动如火如荼,不断有业内的巨头加入阵营,发布和推广NoSQL的相关产品,开拓应用场景。传统关系型数据库软件厂商也不甘寂寞,新产品、新版本、新特性不断发布,新官司、新收购也频频爆出,即使一向沉静的数据库市场,也被震出了几丝波澜。
Enjoy233
2019/03/05
1.8K0
数据库的发展与数据模型
数据库的概念最早可以追溯到1960年,经过多年的发展和演变才有了现在使用广泛的关系型数据库,被企业广泛采用。
一头小山猪
2020/05/19
9830
数据库的发展与数据模型
【数据库08】数据库物理存储系统的选型与管理
当前计算机系统会根据访问速度,介质成本,介质可靠性等,搭配多种不同的存储介质,有代表性的可用存储介质包括。
半旧518
2022/11/18
1.2K0
【数据库08】数据库物理存储系统的选型与管理
针对我国——国产数据库进行分析
Oracle能在所有主流平台上运行(包括Windows),完全支持所有的工业标准,采用完全开放策略,可以使客户选择最适合的解决方案,对开发商全力支持。
用户10196776
2022/11/22
1.2K0
针对我国——国产数据库进行分析
数据库系统设计概述
数据是系统最重要的信息。大部分系统都是对数据的管理。应用系统通过数据模型来构建现实世界,通过算法操作对象或数据结构,来改变数据模型的状态。数据被组织在操作系统文件中,我们通过数据系统来组织,查询,搜索,处理数据。
码哥字节
2020/07/28
2.1K0
推荐阅读
相关推荐
【数据库09】数据库系统体系结构
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验