docker报错standard init linux.go:228 exec user process caused: exec format error

1、报错

使用Dockerfile自己做的服务镜像,docker run时启动失败,报错如下:

java 复制代码
standard init linux.go:228 exec user process caused: exec format error

2、原因一

当前服务器的CPU架构和构建镜像时的CPU架构不兼容。比如做镜像是在arm机器下构建的,而docker run是在amd架构下执行的。排查:

bash 复制代码
# 镜像信息
docker inspect 镜像ID |grep -i Arch

查看当前服务器的CPU架构信息:

bash 复制代码
# Linux信息
uname -a
# 或
lscpu

此时,可通过docker buildx插件模拟多CPU架构,构建出你需要的镜像,从而解决这个问题。

2、原因二

要是前面的这个问题,那倒是明晰,坑就在你明明用docker buildx构建的,查看两个架构信息也没毛病,但还是报这个错。

此时,考虑你Dockfile里的基础镜像,它的架构也要对应上。不能做amd下的镜像,但基础镜像却是arm下的。比如我之前使用JDK的镜像,Dockerfile共用一个,开头都是:

bash 复制代码
FROM openjdk:11.0.4

这个坑得处理掉,可以通过--platform参数来完成指定架构镜像的拉取:

bash 复制代码
docker pull --platform linux/arm64 openjdk:11.0.4
bash 复制代码
docker pull --platform linux/amd64 openjdk:11.0.4

后面我是通过CICD平台的,对应的打包脚本也就变成了:

问题解决!

相关推荐
爱装代码的小瓶子11 分钟前
【C++与Linux】文件篇(2)- 文件操作的系统接口详解
linux·c++
Cisco_hw_zte16 分钟前
挂载大容量磁盘【Linux系统】
linux·运维·服务器
你才是臭弟弟16 分钟前
生产环境开箱即用的“Flink + Iceberg 数据湖容器搭建”(Docker)
docker·容器·jar
DolphinScheduler社区21 分钟前
Linux 环境下,Apache DolphinScheduler 如何驱动 Flink 消费 Kafka 数据?
linux·flink·kafka·开源·apache·海豚调度·大数据工作流调度
艾莉丝努力练剑26 分钟前
【AI时代的赋能与重构】当AI成为创作环境的一部分:机遇、挑战与应对路径
linux·c++·人工智能·python·ai·脉脉·ama
杜子不疼.27 分钟前
【Linux】Ext系列文件系统(一):文件系统的初识
linux·运维·服务器
码农不惑32 分钟前
systemd升级造成的centos-bootc系统的内核故障
linux·centos·bootc
若风的雨39 分钟前
HIP Runtime资源分配相关的核心API分类总结
linux
老友@43 分钟前
JMeter 在 Linux 环境下进行生产级性能压测的完整实战指南
java·linux·jmeter·性能优化·系统架构·压测·性能瓶颈
加强洁西卡1 小时前
【RISC-V】riscv64-linux-gnu工具链都有哪些工具
linux·gnu·risc-v