Docker基础 -- Ubuntu 22.04 AArch64 交叉编译 Docker 镜像构建指南

Ubuntu 22.04 AArch64 交叉编译 Docker 镜像构建指南

作者: (填写作者)  
发布日期: 2025‑05‑26


1 背景与目标

在企业内网(需要代理)环境下,我们需要一套可靠、可复用的 Ubuntu 22.04 交叉编译镜像,用于 ARM64 (AArch64) 固件和内核构建。本文档从零梳理镜像构建全过程,并总结常见坑点与加固方案,便于团队后续快速复制实践。


2 目录结构

.
├── Dockerfile                # 镜像构建文件
└── sources.list.tuna         # 清华 Ubuntu 镜像源(HTTP/HTTPS 可选)

3 TUNA 源文件(sources.list.tuna

版本一定要用 jammy(22.04),勿用 bionic(18.04)!

# 建议使用 HTTP,HTTPS 需先安装 ca-certificates
deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu/ jammy main restricted universe multiverse
deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu/ jammy-updates main restricted universe multiverse
deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu/ jammy-backports main restricted universe multiverse
deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu/ jammy-security main restricted universe multiverse

如需源码仓库或 proposed,请自行取消注释并添加 deb-src/-proposed


4 Dockerfile(HTTPS 方案示例)

FROM ubuntu:22.04ENV DEBIAN_FRONTEND=noninteractive \LANG=C.UTF-8# 1️⃣ 先更新官方源,安装 TLS 根证书
RUN apt-get update && \apt-get install -y --no-install-recommends ca-certificates && \rm -rf /var/lib/apt/lists/*# 2️⃣ 覆盖为清华镜像并刷新索引
COPY sources.list.tuna /etc/apt/sources.list
RUN apt-get update# 3️⃣ 安装交叉工具链与常用构建环境(已删 gcc‑multilib / g++‑multilib,gpgv 替代 gpgv2)
RUN apt-get install -y --no-install-recommends \build-essential git openssh-client make \gcc-aarch64-linux-gnu g++-aarch64-linux-gnu \cpp-aarch64-linux-gnu binutils-aarch64-linux-gnu \libssl-dev liblz4-tool libgmp-dev libmpc-dev \libexpat1-dev libgucharmap-2-90-dev ncurses-dev \bison flex fakeroot cmake unzip bc \device-tree-compiler patchelf chrpath gawk texinfo diffstat \qemu-user-static binfmt-support live-build \expect lz4 gpgv python-is-python3 python2 \&& apt-get clean && rm -rf /var/lib/apt/lists/*# 4️⃣ 启用 qemu-aarch64(宿主内核支持时)
RUN update-binfmt --enable qemu-aarch64 || trueCMD ["/bin/bash"]

HTTP 方案:直接把 sources.list.tuna 中的 https:// 改为 http://,并删除第一阶段安装 ca-certificates 的步骤即可。


5 构建与使用

5.1 构建镜像

# 推荐开启 BuildKit 提升速度
export DOCKER_BUILDKIT=1docker build -t cross-aarch64:22.04 .

5.2 本地使用示例

# 映射当前源代码目录进入容器docker run --rm -it -v "$(pwd)":/workspace cross-aarch64:22.04 bash# 容器中编译内核示例
cd /workspace/linux-source
export CROSS_COMPILE=aarch64-linux-gnu-
make ARCH=arm64 defconfig
make -j$(nproc) ARCH=arm64

5.3 多平台构建(可选)

# 推送到私有 Harbor 并同时生成 x86_64/arm64 两架构镜像
docker buildx build --platform linux/amd64,linux/arm64 \-t harbor.example.com/base/cross-aarch64:22.04 --push .

6 常见报错与排查

错误现象根因解决方案
Certificate verification failed镜像源为 HTTPS,但镜像内无 ca-certificates先安装 ca-certificates 或改用 HTTP 源
gcc-multilib conflicts with gcc‑*-aarch64-linux-gnu两者互斥删除 multilib 或使用多阶段 Dockerfile 分离
Package gpgv2 has no installation candidate22.04 已废弃 gpgv2改装 gpgvgnupg
TLS handshake timeout公司代理或网络慢apt 命令加 -o Acquire::Retries=3 -o Acquire::http::Timeout=30

7 最佳实践

  1. BuildKit 缓存:在 CI/CD 中使用 --cache-from 与共享缓存卷,显著减少二次构建耗时。
  2. 镜像瘦身:如果只需运行环境,使用多阶段将产物拷贝到 FROM scratchalpine
  3. 安全:尽量使用非 root 用户运行编译脚本;定期用 trivy 扫描漏洞。
  4. 代理:在公司代理环境,需同时配置 Docker daemon 与容器内部 apt 代理,避免 407 错误。
  5. 版本锁:给 Dockerfile 固定包版本 (e.g. gcc-aarch64-linux-gnu=11.*) 以保证可重现性。

8 引用与参考

  • Tsinghua Tuna 镜像站说明
  • Ubuntu 22.04 Jammy 官方仓库
  • Docker 官方 BuildKit 文档
  • GNU Arm Embedded Toolchain (Ubuntu cross packages)

版权声明:本文档为原创,遵循 CC BY‑SA 4.0 协议;转载请注明出处。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/web/81421.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【ISP算法精粹】ISP算法管线的预处理算法有哪些?

1. ISP预处理算法有哪些? 在图像信号处理(ISP)流程中,预处理阶段主要针对图像传感器(如CMOS/CCD)输出的原始图像数据(通常为拜耳格式的RAW图像)进行初步处理,以校正硬件…

华为OD机试真题——字符串加密 (2025B卷:100分)Java/python/JavaScript/C/C++/GO最佳实现

2025 B卷 100分 题型 本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式; 并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析; 本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分…

视频存储开源方案

项目成熟度 GitHub - ceph/ceph: Ceph is a distributed object, block, and file storage platform GitHub - minio/minio: MinIO is a high-performance, S3 compatible object store, open sourced under GNU AGPLv3 license. GitHub - seaweedfs/seaweedfs: SeaweedFS i…

典型城市工况数据(Drive Cycle)用于车辆仿真

典型城市工况数据(Drive Cycle)用于车辆仿真 在车辆仿真过程中,使用典型的城市工况数据(Drive Cycle)是评估车辆性能、能耗和排放的关键步骤。以下是一些常用的典型城市工况数据及其来源,这些数据可以帮助…

深度解析新能源汽车结构与工作原理

一、核心系统架构 新能源汽车主要由三大核心系统构成: 电力驱动系统:包含永磁同步电机、电机控制器(MCU)及减速器,采用三合一集成设计实现轻量化。永磁同步电机通过电磁感应原理将电能转化为机械能,其效率可…

跳板问题(贪心算法+细节思考)

首先直接看题&#xff1a; 这题直接贪心其实问题不大&#xff1a; 下面先展示我的一个错误代码&#xff1a; # include<iostream> # include<vector> # include<algorithm>using namespace std;int main() {int N,M;cin>>N>>M;vector<vecto…

pgsql 一些用法

要查询PostgreSQL数据库中剩余的磁盘空间&#xff0c;可以使用以下方法&#xff1a; 使用SQL查询函数&#xff1a; 可以通过pg_size_pretty函数来查看数据库的总磁盘使用情况&#xff0c;例如&#xff1a; SELECT pg_size_pretty(pg_database_size(‘your_database_name’)); …

【三维重建】【3DGS系列】【深度学习】3DGS的理论基础知识之如何形成高斯椭球

【三维重建】【3DGS系列】【深度学习】3DGS的理论基础知识之如何形成高斯椭球 文章目录 【三维重建】【3DGS系列】【深度学习】3DGS的理论基础知识之如何形成高斯椭球前言高斯函数一维高斯多维高斯 椭球基本定义一般二次形式 3D高斯椭球3D高斯与椭球的关系各向同性(Isotropic)和…

unix的定时任务和quartz和spring schedule的cron表达式区别

一、核心区别对比表 对比项Unix CrontabQuartzSpring Scheduled表达式位数5 位6 位或 7 位6 位秒级支持❌ 不支持&#xff08;最小单位是分钟&#xff09;✅ 支持✅ 支持年字段❌ 无✅ 可选第7位❌ 不支持特殊符号支持较少&#xff08;如 *, ,, -, /&#xff09;很丰富和 Quar…

C++基础算法————递推

C++递推:初学者的进阶之旅 一、引言 在计算机编程的世界里,C++ 以其强大的功能和高效性受到众多开发者的青睐。递推作为一种重要的编程思想,在解决各种复杂问题时发挥着关键作用。对于初学者来说,理解并掌握递推不仅可以提升编程能力,还能培养逻辑思维和问题解决能力。本…

QTabWidget垂直TabBar的图标和文本水平显示

一般情况下,我们可以通过QTabWidget的setTabPosition方法来设置TabBar的位置,比如设置在左边 ui->tabWidget->setTabPosition(QTabWidget::West); 但是此时图标和文字都是垂直的,如果让它们水平显示呢? 一.效果 二.原理 在绘制TabBar时,顺时针旋转90度 三.实现 …

HCIP-AI培养计划,成为新时代AI解决方案架构高级工程师

01 华为认证是什么&#xff1f; 华为认证&#xff08;Huawei Certification&#xff09;是面向数字化时代构建的ICT人才培训与认证体系。 当前超过68万来自全球180多个国家和地区的各行业精英已经取得华为认证&#xff0c;如今全球每年超过10万名学员通过考试获得华为认证。 华…

【RabbitMQ】基于Spring Boot + RabbitMQ 完成应用通信

文章目录 需求描述创建项目订单系统(生产者)完善配置声明队列下单接口启动服务 物流系统(消费者)完善配置监听队列启动服务 格式化发送消息对象SimpleMessageConverter定义一个对象生产者代码消费者运行程序 JSON定义一个对象生产者代码定义转换器消费者代码运行程序 需求描述 …

OpenGL Chan视频学习-7 Writing a Shader inOpenGL

bilibili视频链接&#xff1a; 【最好的OpenGL教程之一】https://www.bilibili.com/video/BV1MJ411u7Bc?p5&vd_source44b77bde056381262ee55e448b9b1973 函数网站&#xff1a; docs.gl 说明&#xff1a; 1.之后就不再整理具体函数了&#xff0c;网站直接翻译会更直观也会…

Vue 3.0中复杂状态如何管理

在现代前端应用中&#xff0c;状态管理扮演着至关重要的角色。一个良好的状态管理方案能够&#xff1a; 1. 保持应用数据的一致性和可预测性&#xff1b; 2. 简化组件间的通信和数据共享&#xff1b; 3. 提高代码的可维护性和可测试性&#xff1b; 4. 优化应用性能&#xf…

AGI大模型(33):LangChain之Memory

大多数的 LLM 应用程序都会有一个会话接口,允许我们和 LLM 进行多轮的对话,并有一定的上下文记忆能力。但实际上,模型本身是不会记忆任何上下文的,只能依靠用户本身的输入去产生输出。而实现这个记忆功能,就需要额外的模块去保存我们和模型对话的上下文信息,然后在下一次…

leetcode513. 找树左下角的值:层序遍历中的深度与顺序控制之道

一、题目深度解析与核心诉求 在二叉树的众多问题中&#xff0c;寻找最深层最左节点的值是一个兼具趣味性与代表性的问题。题目要求我们在给定的二叉树中&#xff0c;找到深度最大的那一层中最左边的节点值。如果存在多个最深层&#xff0c;只需返回最左边节点的值即可。 这个…

制作一款打飞机游戏54:子弹编辑UI

今天&#xff0c;我们将继续工作在我们的子弹模式系统上&#xff0c;创建一些简单的子弹&#xff0c;并为其设计用户界面&#xff08;UI&#xff09;。 自动保存功能的重要性 首先&#xff0c;我想提一下自动保存功能。这个功能在编辑器中非常重要&#xff0c;因为我们经常犯…

线程封装与互斥

目录 线程互斥 进程线程间的互斥相关背景概念 互斥量mutex 互斥量的接口 初始化互斥量有两种方法&#xff1a; 销毁互斥量 互斥量加锁和解锁 改进售票系统 互斥量实现原理探究 互斥量的封装 线程互斥 进程线程间的互斥相关背景概念 临界资源&#xff1a;多线程执行流共…

【系统设计】2WTPS生产级数据处理系统设计Review

欢迎来到啾啾的博客&#x1f431;。 记录学习点滴。分享工作思考和实用技巧&#xff0c;偶尔也分享一些杂谈&#x1f4ac;。 有很多很多不足的地方&#xff0c;欢迎评论交流&#xff0c;感谢您的阅读与评论&#x1f604;。 目录 反正能用的系统问题分析方案一&#xff1a;简单多…