docker运行arm64架构的镜像、不同平台镜像构建

背景

Docker 允许开发者将应用及其依赖打包成一个轻量级、可移植的容器,实现"一次构建,到处运行"的目标。然而,不同的操作系统和硬件架构对容器镜像有不同的要求。例如,Linux 和 Windows 系统有不同的文件系统和系统调用,而 x86_64(amd64)和 ARM64 架构则有不同的指令集。

Docker 从 18.09 版本开始支持多平台镜像构建。--platform参数允许用户指定构建过程应该生成的目标操作系统和架构。例如,--platform=linux/amd64指定生成一个在 64 位 Linux 操作系统上运行的镜像

操作系统架构概览

在讨论--platform参数之前,我们需要了解一些常见的操作系统架构:

amd64:即 x86_64,是最常见的桌面和服务器 CPU 架构,广泛用于 Intel 和 AMD 的处理器,这个就是x86架构的。

arm64:ARM 架构的 64 位版本,常用于移动设备和一些高性能计算场景。

windows/amd64:指运行在 64 位 Windows 操作系统上的架构。

开启platform参数

docker默认没有开启 --platform 参数,需要手动开启

docker info | grep -i 'experimental'

修改daemon.json文件

{
  "experimental": true,
   "registry-mirrors": ["https://dockerpull.com"]
}

重启docker

systemctl daemon-reload
systemctl restart docker

修改完成后,重启 docker 来验证

安装 qemu 多平台支持

下载多架构支持的包,注意选对目标架构

qemu-aarch64-static 是arm-arch64架构的包

wget https://github.com/multiarch/qemu-user-static/releases/download/v5.1.0-5/qemu-aarch64-static.tar.gz

qemu-aarch64-static.tar.gz已上传到csdn资源上

https://download.csdn.net/download/wjzholmes/89839670

解压

tar xzvf qemu-aarch64-static.tar.gz

配置可执行文件路径,增加权限

sudo cp qemu-aarch64-static /usr/bin/
chmod +x /usr/bin/qemu-aarch64-static

注册qemu-user-static虚拟机

docker run --rm --privileged multiarch/qemu-user-static:register --reset

(作用是注册一些什么东西,可以用先不考虑具体内容)

--rm 容器退出时自动移除

--privileged 赋予容器拓展的权限

--reset (启动时传递给容器的参数) 即:/register --reset

启动nginx的arm镜像

docker run -itd --platform linux/arm64 -v /usr/bin/qemu-aarch64-static:/usr/bin/qemu-aarch64-static --name=nginx_arm -p 8081:80 nginx:arm114

启动nginx的x86镜像

docker run -itd --name=nginx_x86 -p 8082:80 nginx:latest

启动镜像后web访问NGINX不通,查看是镜像内NGINX未启动,登录镜像启动nginx

docker exec -it nginx_x86 /bin/bash
service nginx status
service nginx start

查看arm和x86的nginx镜像都启动

参考文章:

【Docker系列】跨平台 Docker 镜像构建:深入理解`--platform`参数_docker --platform-CSDN博客

x86 平台利用 qemu-user-static 实现 arm64 平台 docker 镜像的运行和构建_docker_chen2ha-云原生

【无标题】_qemu-aarch64-static 源码下载-CSDN博客

相关推荐
飘逸高铁侠2 小时前
docker export/import 和 docker save/load 的区别
docker·容器·eureka
Wang's Blog3 小时前
Redis: 集群架构,优缺点和数据分区方式和算法
数据库·redis·架构
长天一色6 小时前
【Docker从入门到进阶】04.高效实践
运维·docker·容器
binqian6 小时前
【Docker】 进入容器的几种方式
运维·docker·容器
执于代码6 小时前
6.5 监控和日志 架构模式和应用实践
java·网络·架构
弥琉撒到我9 小时前
微服务JMeter解析部署使用全流程
jmeter·spring cloud·微服务·架构
Dylanioucn9 小时前
【分布式微服务云原生】OpenFeign:微服务通信的瑞士军刀
分布式·微服务·云原生
杨浦老苏10 小时前
Markdown笔记管理工具Haptic
笔记·docker·markdown·群晖
爱吃牛肉的大老虎11 小时前
Oracle架构之物理存储之审计文件
数据库·oracle·架构