Linux文件系统的安全保障
Linux文件系统的安全保障
`overlayroot` 是一种使用 OverlayFS 实现的功能,可将根文件系统挂载为只读,并通过一个临时的写层实现对文件系统的修改。这种方法非常适合嵌入式设备或需要保持系统文件完整性和安全性的场景。下文以 RK568 平台为例,介绍制作 overlayroot 的详细步骤。
1. 制作精简文件系统ramdisk
1.1 环境准备
1. 目标系统:确保系统支持 OverlayFS(内核版本 ≥ .18)。
2. 工具和依赖:
- 一个支持 OverlayFS 的 Linux 内核。
- `busybox` 或其他必要的系统工具。
1.2 OverlayFS 的基本原理
OverlayFS 将文件系统分为以下两层:
- Lowerdir:只读的底层文件系统,通常是现有的根文件系统。
- Upperdir:可写的顶层,存储所有的临时更改。
- Workdir:OverlayFS 的工作目录,用于支持文件操作。
1. 制作步骤
1..1 创建 OverlayFS 配置结构
首先创建一个工作目录来组织文件系统结构。
代码语言:javascript代码运行次数:0运行复制mkdir -p /tmp/ramdisk/{bin,sbin,etc,proc,sys,dev,tmp}
- bin 和 sbin:存放用户工具(例如 busybox)。
- etc:存放必要的配置文件。
- proc、sys、dev:为内核文件系统挂载预留的挂载点。
- tmp:用于临时存储文件。
将 busybox 和相关依赖文件复制到适当的目录
1..2 配置挂载脚本
在ramdisk 的脚本中配置相关的挂载和优化
代码语言:javascript代码运行次数:0运行复制root_rw=/userdata #读写挂载点
root_ro=/root-ro #只读文件系统挂载点
ROOTMT=${rootmnt} # use global name to indicate created outside this
OVERLAYROOT_DEBUG=0
#优化userdata分区自动修复
e2fsck -y /dev/disk/by-partlabel/userdata
tune2fs -O has_journal /dev/disk/by-partlabel/userdata
2. ramdisk.img 镜像打包和解包制作
2.1 打包脚本
创建脚本 pack_ramdisk.sh,将 RAMDisk 内容打包为 ramdisk.img:
代码语言:javascript代码运行次数:0运行复制#!/bin/bash
cd ramdisk_contents
find .| cpio -o -H newc >../
gzip ../
mv ../.gz ../ramdisk.img
2.2 解包脚本
创建脚本 unpack_ramdisk.sh,将 ramdisk.img 解包到工作目录:
代码语言:javascript代码运行次数:0运行复制#!/bin/bash
mkdir ramdisk_contents
cd ramdisk_contents
gunzip -c ../ramdisk.img >
cpio -idv <
rm
通过上面打包解包脚本可以直接修改已经制作好的ramdisk.img镜像
. 打包到boot.img
.1 配置项目文件
在项目 defconfig 文件中,添加以下内容:
代码语言:javascript代码运行次数:0运行复制RK_USE_FIT_IMG=y
RK_BOOT_FIT_ITS="bootramdisk.its"
RK_RAMDISK_IMG="ramdisk.img"
在 rk56x_bsp/device/rockchip/common/scripts/mk-kernel.sh 文件中添加打包逻辑:
代码语言:javascript代码运行次数:0运行复制 if[-n "$RK_BOOT_FIT_ITS"]; then
if[-z "$RK_ROOTFS_IITRD"]; then
run_command \
"$SCRIPTS_DIR/mk-fitimage.sh" \
"build-$VAXOAK_CUSTOMER_AME/kernel/$RK_BOOT_IMG" \
"$RK_BOOT_FIT_ITS" \
"build-$VAXOAK_CUSTOMER_AME/$RK_KEREL_IMG" \
"build-$VAXOAK_CUSTOMER_AME/kernel/$RK_RAMDISK_IMG"
fi
fi
4. Kernel 配置与设备树修改
4.1 设备树配置修改
修改设备树文件 chosen 节点,添加 overlayroot 参数:
代码语言:javascript代码运行次数:0运行复制 chosen: chosen {
//bootargs = "earlycon=uart8250,mmio2,0xfe660000 cole=ttyFIQ0 root=PARTUUID=614e0000-0000 rw rootwait";
bootargs ="earlycon=uart8250,mmio2,0xfe660000 cole=ttyFIQ0 root=PARTLABEL=rootfs rootfstype=ext4 ro rootwait overlayroot=device:dev=PARTLABEL=userdata,fstype=ext4,mkfs=1 coherent_pool=1m systemd.gpt_auto=0 cgroup_enable=memory swapaccount=1 swiotlb=0x10000 net.ifnames=0";
};
4.2 修改内核配置
确保内核启用了 OverlayFS:
代码语言:javascript代码运行次数:0运行复制COFIG_OVERLAY_FS=y
5. 测试效果与优化
将更新后的 boot.img 刷写到开发板,重启后执行:
代码语言:javascript代码运行次数:0运行复制df -h
输出类似以下内容:
代码语言:javascript代码运行次数:0运行复制root@hd-rk568:~# df -h
文件系统 容量 已用 可用已用% 挂载点
udev 96M 8.0K 96M 1%/dev
tmpfs 196M 1.M 195M 1%/run
/dev/mmcblk0p6 .2G .1G 0 100%/root-ro
/dev/mmcblk0p8 2G 590M 2G %/userdata
overlayroot 2G 590M 2G %/
添加完上面内容后,更新boot.img到开发板,执行df -h命令可以看到rootfs分区挂载为/root-ro变为只读分区,userdata分区挂载为overlayroot保存文件系统修改差异部分。若要重置系统状态,只需清空userdata内容即可。
6. 总结
通过以上步骤,您可以成功为 RK568 平台配置 overlayroot。这种设置使得系统文件更加安全,同时提供灵活的更新和重置能力,非常适合嵌入式场景。
#感谢您对电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格的认可,转载请说明来源于"电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格
上一篇:SpringBoot工程打包部署
推荐阅读
留言与评论(共有 20 条评论) |
本站网友 air医生 | 19分钟前 发表 |
Linux文件系统的安全保障 `overlayroot` 是一种使用 OverlayFS 实现的功能 | |
本站网友 jiagong | 18分钟前 发表 |
同时提供灵活的更新和重置能力 | |
本站网友 高大女人 | 29分钟前 发表 |
6. 总结通过以上步骤 | |
本站网友 苦丁茶的功效与作用 | 18分钟前 发表 |
将 busybox 和相关依赖文件复制到适当的目录1..2 配置挂载脚本在ramdisk 的脚本中配置相关的挂载和优化代码语言:javascript代码运行次数:0运行复制root_rw=/userdata #读写挂载点 root_ro=/root-ro #只读文件系统挂载点 ROOTMT=${rootmnt} # use global name to indicate created outside this OVERLAYROOT_DEBUG=0 #优化userdata分区自动修复 e2fsck -y /dev/disk/by-partlabel/userdata tune2fs -O has_journal /dev/disk/by-partlabel/userdata2. ramdisk.img 镜像打包和解包制作2.1 打包脚本创建脚本 pack_ramdisk.sh | |
本站网友 深圳供电局网上营业厅 | 12分钟前 发表 |
1. 制作步骤1..1 创建 OverlayFS 配置结构首先创建一个工作目录来组织文件系统结构 | |
本站网友 厦门个人房屋出租 | 28分钟前 发表 |
更新boot.img到开发板 | |
本站网友 吃什么水果降火 | 21分钟前 发表 |
非常适合嵌入式场景 | |
本站网友 海尔驱动 | 3分钟前 发表 |
可将根文件系统挂载为只读 | |
本站网友 加减号 | 15分钟前 发表 |
0xfe660000 cole=ttyFIQ0 root=PARTLABEL=rootfs rootfstype=ext4 ro rootwait overlayroot=device | |
本站网友 吃什么容易生男孩 | 3分钟前 发表 |
fstype=ext4 | |
本站网友 兴山政府网 | 25分钟前 发表 |
1.2 OverlayFS 的基本原理OverlayFS 将文件系统分为以下两层:Lowerdir:只读的底层文件系统 | |
本站网友 中国证券协会网 | 14分钟前 发表 |
下文以 RK568 平台为例 | |
本站网友 韩式整形医院 | 4分钟前 发表 |
0xfe660000 cole=ttyFIQ0 root=PARTUUID=614e0000-0000 rw rootwait"; bootargs ="earlycon=uart8250 | |
本站网友 精密加工 | 6分钟前 发表 |
Upperdir:可写的顶层 | |
本站网友 三维弹球太空军校生 | 20分钟前 发表 |
只需清空userdata内容即可 | |
本站网友 盐城租房 | 20分钟前 发表 |
tmp:用于临时存储文件 | |
本站网友 北京哪个整形医院最好 | 13分钟前 发表 |
proc | |
本站网友 伊美尔幸福医院 | 19分钟前 发表 |
将 RAMDisk 内容打包为 ramdisk.img:代码语言:javascript代码运行次数:0运行复制#!/bin/bash cd ramdisk_contents find .| cpio -o -H newc >../ gzip ../ mv ../.gz ../ramdisk.img2.2 解包脚本创建脚本 unpack_ramdisk.sh | |
本站网友 广州社区论坛 | 28分钟前 发表 |
非常适合嵌入式场景 |