当前位置: 首页 > news >正文

Docker基础 -- 构建 RK3588 Debian 根文件系统

在 Docker 容器中成功构建 RK3588 Debian 根文件系统的实践记录

在进行 RK3588 平台的 Debian 根文件系统构建过程中,我尝试在 Docker 容器内执行官方提供的构建脚本,但遇到了 qemu-aarch64-static 无法工作的错误提示。本文将完整记录问题排查与解决流程,供有类似需求的开发者参考。


🧩 问题背景

在执行 ./build.sh debian 构建命令时,出现如下错误:

==========================================Start building rootfs(debian)
==========================================Your qemu-aarch64-static(qemu-user-static) is broken
Please reinstall it:
sudo apt-get install binfmt-support qemu-user-static --reinstall

脚本最终退出,构建失败。


📌 问题分析

该错误本质上是因为:

  • 构建 Debian 根文件系统过程中涉及到 chrootdebootstrap
  • Debian 是为 ARM64 架构 构建的,而当前运行环境是 x86 架构;
  • 因此需要通过 qemu-aarch64-static 提供用户态 ARM64 模拟;
  • 但 Docker 容器中缺少对 binfmt_misc 和 qemu 模拟器的支持,导致模拟失败。

✅ 解决方案步骤

1️⃣ 主机上安装并注册 QEMU 模拟器

sudo apt update
sudo apt install qemu-user-static binfmt-support -y
sudo update-binfmts --enable qemu-aarch64

2️⃣ 确认 binfmt_misc 注册成功

ls /proc/sys/fs/binfmt_misc/ | grep aarch64

如果没有注册成功,可尝试:

docker run --rm --privileged tonistiigi/binfmt --install all

或者:

docker run --rm --privileged multiarch/qemu-user-static --reset -p yes

3️⃣ 构建容器时挂载 qemu-aarch64-static

确保容器内存在该模拟器:

docker run --rm -it \--privileged \-v /usr/bin/qemu-aarch64-static:/usr/bin/qemu-aarch64-static \-v `pwd`:/build \ubuntu:22.04 bash

也可选择在 Dockerfile 中 COPY 进去。


4️⃣ 验证模拟器是否工作

在容器中测试:

qemu-aarch64-static /build/path/to/your/aarch64_binary

如果程序能运行且无报错,则模拟器工作正常。


5️⃣ 重新执行构建脚本

cd /build/rk3588_v_6_1_debian
./build.sh debian

最终系统正常执行构建流程,生成 Debian 根文件系统及桌面环境。


🎯 总结

项目操作
构建方式使用 Docker 容器运行 Ubuntu 构建环境
架构支持通过 QEMU 支持 ARM64 的 rootfs 构建
关键配置qemu-aarch64-staticbinfmt_misc 注册
推荐操作使用 --privilegedqemu-aarch64-static 映射
成果成功生成 RK3588 Debian 桌面系统 Rootfs

📚 建议

  • 如果频繁构建,可将此流程封装为统一的 Dockerfile + 启动脚本;
  • 对于构建自动化推荐搭配 Jenkins + 构建缓存(如 ccache);
  • 若需要调试完整桌面环境,可将生成的 rootfs 转移至开发板测试。
http://www.xdnf.cn/news/655237.html

相关文章:

  • 中建海龙携MiC技术亮相双博会 引领模块化建筑新潮流
  • 集成30+办公功能的实用工具
  • 【文章速读】Tim Ferriss《每周工作4小时》
  • C++异步日志系统
  • Keepalived及相关项目
  • 文档工具解析:前端如何选择最适合的文档生成器?
  • PHPStorm运行Thinkphp8.0项目
  • xhr、fetch和axios
  • 无人机降落伞设计要点难点及原理!
  • 基于 uni-app + <movable-view>拖拽实现的标签排序-适用于微信小程序、H5等多端
  • ESP32 LVGL btn事件、label赋值、ddlist选项读取
  • NGINX 用户标识模块 (ngx_http_userid_module) 完整配置与最佳实践指南
  • 知识宇宙-职业篇:嵌入式工程师
  • Pycatia基础代码解析——零件设计篇(一)
  • ATT衰减器(Attenuator)介绍
  • 华为OD机试真题——洞穴探险(2025A卷:200分)Java/python/JavaScript/C/C++/GO最佳实现
  • BGP配置命令详细框架
  • 营销推广需要解决哪些问题?
  • IP SSL证书:为IP地址提供安全加密的专业解决方案
  • 【论文解读】STaR:不用人类思维链指导,模型可以自我进化!
  • Go Web框架选型与实践:基于Gin的REST API开发指南
  • 【R语言科研绘图-最小二乘法】
  • 【混合动力能量管理新突破:负载识别优化策略深度解析与仿真实战】
  • [yolov11改进系列]基于yolov11引入级联群体注意力机制CGAttention的python源码+训练源码
  • 鸿蒙OSUniApp 实现带有滑动删除的列表#三方框架 #Uniapp
  • 基于GitHub Actions+SSH+PM2的Node.js自动化部署全流程指南
  • Nacos集群
  • 【向量数据库选型实战】FAISS vs Chroma vs Milvus vs Qdrant 全面对比
  • 【QT】QString和QStringList去掉空格的方法总结
  • day38python打卡