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

跨架构镜像打包问题及解决方案

问题背景:

  • 需求:
    • 有一个镜像是 docker.io 的,是 docker.io/aquasec/kube-bench:v0.10.6,我想把该镜像在本地电脑(可翻墙)下载下来,然后 docker save 打包成一个 tar 包,传输到服务器上。
  • 环境:
    • 本地电脑:MacOS 14.5 (ARM64)
    • Docker Desktop:4.41.2 (191736)
    • Docker Engine:28.1.1

问题现象

我的电脑是 arm64 架构,我考虑通过 docker pull --platform=linux/amd64 下来镜像,然后 docker save 成一个 tar 包,传输到服务器上,直接 docker load 使用,具体命令如下:

# 拉取 linux/amd64 架构镜像
docker pull --platform=linux/amd64 docker.io/aquasec/kube-bench:v0.10.6# 打包镜像为tar包
docker save -o kube-bench.tar docker.io/aquasec/kube-bench:v0.10.6

但是在执行 docker save 命令时,报错信息:
Error response from daemon: unable to create manifests file: NotFound: content digest sha256:b544d2a5cba58aa28c123fe2a535893f607d4f6b62a38db370c4dcc3a6a275e6: not found

根因分析:

详细原因参考:https://github.com/docker/cli/issues/5476

  1. Docker Desktop Bug:当宿主机与目标镜像架构不同时,docker save 错误地尝试访问宿主机架构(ARM64)的manifest数据。
  2. 预期行为:save 操作应仅打包已拉取的指定架构(AMD64)镜像数据,不应检查其他架构
  3. 补充验证:相同操作在Ubuntu AMD64主机上保存ARM64镜像可成功(反向场景正常)

补充:该问题属于是 docker desktop 的一个bug了,同样的操作,我在 ubuntu amd64 服务上,使用 docker save 一个 arm64 架构的镜像,可以正常 docker save 成功。

save 失败是因为 docker 在 save 时去找了 arm64 架构镜像的元数据(b544d2a5cba58aa28c123fe2a535893f607d4f6b62a38db370c4dcc3a6a275e6 就是 arm64 架构镜像的sha256),发现没找到,就报错了,正常情况不应该报错,因为 save 操作其实就是将镜像元数据和 layer 层打包就可以了。

解决方案:

docker save 时显式指定平台参数:

# 打包指定架构镜像为tar包
docker save -o kube-bench.tar --platform=linux/amd64 docker.io/aquasec/kube-bench:v0.10.6

可以正常 save 成功。

建议

  1. 完整性验证:传输后可在服务器执行 docker load -i kube-bench.tar && docker inspect --format=‘{{.Architecture}}’ <IMAGE_ID> 确认架构
  2. 替代方案:考虑使用 skopeo 工具(更适合跨架构镜像操作)
  3. 长期方案:关注Docker Desktop更新,该问题可能在未来版本修复
http://www.lryc.cn/news/2398669.html

相关文章:

  • 云原生时代 Kafka 深度实践:05性能调优与场景实战
  • Ubuntu安装Docker命令清单(以20.04为例)
  • 使用 Python 制作 GIF 动图,并打包为 EXE 可执行程序
  • HarmonyOS Next 弹窗系列教程(2)
  • Ubuntu 18.04 上源码安装 protobuf 3.7.0
  • 中小企业搭建网站选择虚拟主机还是云服务器?华为云有话说
  • 使用 HTML + JavaScript 在高德地图上实现物流轨迹跟踪系统
  • 19-项目部署(Linux)
  • html基础01:前端基础知识学习
  • Golang学习之旅
  • 【RoadRunner】自动驾驶模拟3D场景构建 | 软件简介与视角控制
  • 基于RK3576+FPGA芯片构建的CODESYS软PLC Linux实时系统方案,支持6T AI算力
  • 鸿蒙OSUniApp复杂表单与动态验证实践:打造高效的移动端表单解决方案#三方框架 #Uniapp
  • 在linux系统上搭建git服务器(ssh协议)
  • 适配器模式:让不兼容接口协同工作
  • NodeJS全栈开发面试题讲解——P12高性能场景题
  • DDP与FSDP:分布式训练技术全解析
  • 【Spring AI 1.0.0】Spring AI 1.0.0框架快速入门(1)——Chat Client API
  • 【笔记】在 MSYS2(MINGW64)中正确安装 Rust
  • 从汇编的角度揭秘C++引用,豁然开朗
  • 设计模式系列(07):建造者模式(Builder)
  • Maven 项目中集成数据库文档生成工具
  • 聊聊Tomato Architecture
  • 小白的进阶之路系列之十二----人工智能从初步到精通pytorch综合运用的讲解第五部分
  • Java并发编程实战 Day 6:Future与异步编程模型
  • .NET Core 中预防跨网站请求伪造 (XSRFCSRF) 攻击
  • MFC Resource.h 文件详解与修改指南
  • 2025年06月03日Github流行趋势
  • AI视频编码器(0.4.3) 调试训练bug——使用timm SoftTargetCrossEntropy时出现loss inf
  • 【数据分析】基于Cox模型的R语言实现生存分析与生物标志物风险评估