10、Linux根文件系统的制作

2024-08-31 06:58
文章标签 linux 制作 文件系统

本文主要是介绍10、Linux根文件系统的制作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

根文件系统的制作

 

1、建立根文件系统及目录

 

 

1.1 创建目录

#mkdir rootfs
#cd rootfs
#mkdir bin dev etc lib proc sbin sys usr mnt tmp var
#mkdir usr/bin usr/lib usr/sbin lib/modules

 

 

 

 

 

1.2 创建设备文件

Linux系统中,绝大部分的设备通过文件来操作,通过文件读写来实现对设备的读写
dev目录下存放各种设备文件,console文件和null目录必需的,用mknod创建设备文件
#cd rootfs/dev
#mknod -m 666 console c 5 1
#mknod -m 666 null c 1 3


c代表的是字符设备,5是主设备号,1是次设备号

 

 

 

 

 

 

1.3 加入配置文件

首先需要下载etc.tar.gz文件
#tar etc.tar.gz
把解压后的所有文件拷贝到rootfs文件下
#mv etc/* rootfs/etc/ -rf

 

 

 

 

 

 

 

 

1.4 添加内核模块

往根文件系统中添加内核模块
进入内核代码
#cd …/linux
编译内核模块
#make modules ARCH=arm CROSS_COMPILE=arm-linux-
把编译好的内核模块复制到rootfs目录下(...为rootfs目录前缀)
#make modules_install ARCH=arm INSTALL_MOD_PATH=…/rootfs

 

 

 

 

 

 

 

 

 

 

1.5 编译busybox

Busybox: 嵌入式开发中的瑞士军刀,提供嵌入式开发中很多的的命令、小工具
先下载busybox源代码,解压后进去文件夹中
配置busybox
#make menuconfig
在Busybox Settings àbuild Options->
选中 “Build busybox as a static binary”, 静态链接
Cross Compiler prefix (arm-linux-)配置成arm-linux-




Installation Options->
选中 “Don‘t use /usr”, 选中该项可以避免busybox 被安装到宿主系统的/usr目录下,破坏宿主系统


Busybox Installation Prefix (/xxx/rootfs)
该选项表明编译后的busybox的安装位置


开始编译
make
make install


进入rootfs->bin目录
可以看到包含了很多命令,说明编译安装成功

 

 

 

 

 

 

 

 

 

 

2、挂载根文件系统到内核

 

 

 

 

 

 

 

2.1 挂载方式

文件系统类型有很多,主要有:
initramfs、NFS、Yaffs2、UbiF5、Jffs2、Ramdisk

 

 

 

 

 

 

 

2.2 挂载initramfs文件系统

基于内存的文件系统,主要用于产品,优点是访问速度快,缺点是根文件系统发生变化时都要重新制作一遍,下面是建立initramfs文件系统的步骤
进入rotfs创建软连接,名字叫做init
#cd …/rootfs/
#ln –s ./bin/busybox  init
配置Linux内核,支持initramfs,运行
#make menuconfig ARCH=arm
选择->General setup->Initial RAM *****
配置下面目录为根文件系统目录****/rootfs/
编译内核
#make uImage ARCH=arm CROSS_COMPILE=arm-linux-
拷贝uImage到/tftpboot/目录下


进入到U-boot,配置环境变量,U-boot通过bootargs告诉内核以什么样的方式启动
#setenv bootargs noinitrd console=ttySAC0,115200


下载并启动linux内核:
#tftp 31000000 uImage
#bootm 31000000


到这里根文件系统就挂载成功了


initramfs编译出来的内核由2部分构成,一部分是真正的内核,另一部分是文件系统在制作initramfs时会把rootfs文件目录的文件压缩贴在uImage文件上,uImage在启动时会把文件系统解压到内存中运行。

 

 

 

 

 

 

 

 

2.3 挂载NFS文件系统

基于网络的文件系统,主要用于开发阶段,通过NFS可以非常方便的往开发板中添加文件


首先需要对内核进行配置
#make menuconfig ARCH=arm
进入General setup,取消掉Initial RAM *****,然后进入File system选中Network File Systems,保证Root file system on NFS是选上的,Network File Systems也要选上


进行内核编译
#make uImage ARCH=arm CROSS_COMPILE=arm-linux-


进入到U-boot,配置环境变量
setenv bootargs noinitrd console=ttySAC0,115200 init=/init root=/dev/nfs rw nfsroot=192.168.1.3:/home/unix/NO.3/3-rootfs/rootfs ip=192.168.1.4:192.168.1.3:192.168.1.1:255.255.255.0::eth0:off


console的配置表示使用串口作为控制台,波特率为115200
root表示使用/dev/nfs作为根文件系统
nfsroot用来指明NFS服务器的地址,即Linux的地址,后面的冒号是制作的根文件系统的路径
要选择和自己相符的路径,
ip第一项是启动后自己的ip地址,第二项是NFS服务器地址,第三项是网关,第四项是掩码,中间可以给
开发板取主机名,这里空掉,eth0表示启动后把ip地址赋值给eth0网卡,off表示关闭动态ip获取功能


保存环境变量
#saveenv


启动前需要保证Linux启动了NFS并配置了,NFS的启动及配置见http://blog.csdn.net/u013181595/article/details/72566910


下载并启动linux内核:
#tftp 31000000 uImage
#bootm 31000000


验证
在Linux主机制作的rootfs目录下新增一个测试文件,然后查看开发板中是否新增了该文件,如果增加成功
说明NFS文件系统也就制作成功了!


这种方式下的文件系统使用网络,虚拟机和开发板的文件系统保持一致,开发阶段使用非常方便

 

更多Linux资料及视频教程点击这里

 

 

 

 

这篇关于10、Linux根文件系统的制作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux磁盘分区、格式化和挂载方式

《Linux磁盘分区、格式化和挂载方式》本文详细介绍了Linux系统中磁盘分区、格式化和挂载的基本操作步骤和命令,包括MBR和GPT分区表的区别、fdisk和gdisk命令的使用、常见的文件系统格式以... 目录一、磁盘分区表分类二、fdisk命令创建分区1、交互式的命令2、分区主分区3、创建扩展分区,然后

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch

Linux内核之内核裁剪详解

《Linux内核之内核裁剪详解》Linux内核裁剪是通过移除不必要的功能和模块,调整配置参数来优化内核,以满足特定需求,裁剪的方法包括使用配置选项、模块化设计和优化配置参数,图形裁剪工具如makeme... 目录简介一、 裁剪的原因二、裁剪的方法三、图形裁剪工具四、操作说明五、make menuconfig

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min

Linux使用nohup命令在后台运行脚本

《Linux使用nohup命令在后台运行脚本》在Linux或类Unix系统中,后台运行脚本是一项非常实用的技能,尤其适用于需要长时间运行的任务或服务,本文我们来看看如何使用nohup命令在后台... 目录nohup 命令简介基本用法输出重定向& 符号的作用后台进程的特点注意事项实际应用场景长时间运行的任务服

什么是cron? Linux系统下Cron定时任务使用指南

《什么是cron?Linux系统下Cron定时任务使用指南》在日常的Linux系统管理和维护中,定时执行任务是非常常见的需求,你可能需要每天执行备份任务、清理系统日志或运行特定的脚本,而不想每天... 在管理 linux 服务器的过程中,总有一些任务需要我们定期或重复执行。就比如备份任务,通常会选在服务器资

Linux限制ip访问的解决方案

《Linux限制ip访问的解决方案》为了修复安全扫描中发现的漏洞,我们需要对某些服务设置访问限制,具体来说,就是要确保只有指定的内部IP地址能够访问这些服务,所以本文给大家介绍了Linux限制ip访问... 目录背景:解决方案:使用Firewalld防火墙规则验证方法深度了解防火墙逻辑应用场景与扩展背景:

使用Python制作一个PDF批量加密工具

《使用Python制作一个PDF批量加密工具》PDF批量加密‌是一种保护PDF文件安全性的方法,通过为多个PDF文件设置相同的密码,防止未经授权的用户访问这些文件,下面我们来看看如何使用Python制... 目录1.简介2.运行效果3.相关源码1.简介一个python写的PDF批量加密工具。PDF批量加密

Linux下MySQL8.0.26安装教程

《Linux下MySQL8.0.26安装教程》文章详细介绍了如何在Linux系统上安装和配置MySQL,包括下载、解压、安装依赖、启动服务、获取默认密码、设置密码、支持远程登录以及创建表,感兴趣的朋友... 目录1.找到官网下载位置1.访问mysql存档2.下载社区版3.百度网盘中2.linux安装配置1.

Linux使用粘滞位 (t-bit)共享文件的方法教程

《Linux使用粘滞位(t-bit)共享文件的方法教程》在Linux系统中,共享文件是日常管理和协作中的常见任务,而粘滞位(StickyBit或t-bit)是实现共享目录安全性的重要工具之一,本文将... 目录文件共享的常见场景基础概念linux 文件权限粘滞位 (Sticky Bit)设置共享目录并配置粘