Docker buildx构建多平台镜像并推送到私有仓库的方法

作者:蓝胖子 时间:2022-01-12 22:53:14 

引子

最近发现有ARM版Docker,hub.docker.com上也有ARM版本的镜像,但是ARM版本的Docker镜像构建是个问题。嵌入式程序可以在PC机上进行交叉编译,不知道Docker是否有交叉构建的方案。

方案

目前想到的Docker构建ARM镜像方法有如下几种。第三种就类似交叉编译。

  1. 使用ARM主机,安装ARM版本的Docker,docker build出来的就是ARM版本的镜像。

  2. 使用Linux的虚拟化软件,模拟ARM芯片+ Linux,例如qemu。

  3. 使用Docker试验功能buildx,可以构建多平台的镜像。

使用Docker buildx构建多个平台镜像

参考如下几个链接。
https://docs.docker.com/engine/reference/commandline/manifest/
https://docs.docker.com/buildx/working-with-buildx/
https://engineering.docker.com/2019/06/getting-started-with-docker-for-arm-on-linux/

用到了两个docker的试验功能,使用时需要开启试验功能。

docker manifest,manifest是一个包含了镜像信息的文件。manifest list是一个镜像清单列表,用于存放不同os/arch的镜像信息。我们可以创建一个manifest list来指向两个镜像,然后可以支持多平台。

docker buildx,buildx是docker的一个插件,是下一代docker镜像构建。该插件通过qemu-user-static翻译不同平台的指令集,达到在x64上运行其他平台的程序。buildx实际使用了moby/buildkit:buildx-stable-1镜像进行多平台构建。

搭建docker registry多平台版本

参考如下链接,构建docker registry镜像。
https://community.arm.com/developer/tools-software/tools/b/tools-software-ides-blog/posts/deploying-multi-architecture-docker-registry

搭建dns服务器,解决buildx bug

buildx插件不走本地hosts文件,必须走dns。这是个bug,https://github.com/docker/buildx/issues/218,社区也没人管。
解决方法:自建dns,把镜像的地址buildx.com指向registry的机器,后续用nginx。ubuntu有一个默认systemd-resolved,关闭之后在开启dnsmasq。

使用nginx代理解决命名问题

增加nginx代理同时支持HTTP和HTTPS。buildx这个插件强行使用了HTTPS,没有找到关闭的地方。
提示证书问题,证书不是这个域名的,解决方法: 重新生成一个证书,域名填自己的。
证书问题,不信任自签名证书,把自签名的证书加到buildx daemon容器的证书信任链中。https://github.com/docker/buildx/issues/80#issuecomment-533844117

nginx增加两个配置,解决客户端push时的几个问题。


# nignx.conf 配置
proxy_ignore_client_abort on; #忽略客户端告警
client_max_body_size 0;  #上传文件大小不限制

# 虚拟主机配置
server {
 listen 443;
 server_name buildx.com;
 ssl on;
 ssl_certificate crt/server.crt;
 ssl_certificate_key crt/server.key;
 ssl_session_timeout 5m;
 ssl_protocols TLSv1 TLSv1.1 TLSv1.2; #按照这个协议配置
 ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;#按照这个套件配置
 ssl_prefer_server_ciphers on;
 location / {
   proxy_pass http://192.168.1.11:81;
 }
}

server {
 listen 80;
 server_name buildx.com;
 location / {
   proxy_pass http://192.168.1.11:81;
 }
}

设置本地Docker环境

本地Docker需要开启实验功能。

  1. 在/etc/docker/daemon.json中配置 "experimental": true,重启Docker。开启Docker daemon的实验功能。

  2. 在本地执行export DOCKER_CLI_EXPERIMENTAL=enabled,开启Docker Client的实验功能。

  3. 使用docker version查看实验功能是否开启。

  4. 执行docker run --rm --privileged docker/binfmt:820fdd95a9972a5308930a2bdfb8573dd4447ad3,开启内核binfmt_misc功能,可以在当前平台上执行多平台的程序。

  5. 查看是否支持aarch64程序。cat /proc/sys/fs/binfmt_misc/qemu-aarch64

  6. 此时本地的docker可以运行各种平台的docker容器。比如arm64。可以使用如下命令测试。


# 拉取arm64版本镜像并运行
docker pull --platform arm64 alpine:3.10
docker run --rm -it alpine:3.10 sh

制作基础镜像

可以从hub.docker.com中获取多个平台的版本,生成manifest list,上传的registry中。


# pull arm64版本、改名、上传。 具体镜像是否支持多平台,可以到hub.docker.com上看。
docker pull --platform arm64 centos:7
docker tag centos:7 buildx.com/base/centos-arm64:7
docker push buildx.com/base/centos-arm64:7
# pull amd64版本、改名、上传
docker pull --platform amd64 centos:7
docker tag centos:7 buildx.com/base/centos-amd64:7
docker push buildx.com/base/centos-amd64:7
# 创建manifest list、上传。
docker manifest create --insecure buildx.com/base/centos:7 buildx.com/base/centos-amd64:7 buildx.com/base/centos-arm64:7
docker manifest push --insecure buildx.com/base/centos:7

构建业务镜像


# buildx 可以指定多个平台,但是要求Dockerfile中的FROM镜像必须有对应版本的。
# buildx 打包的镜像不会在本地存储,加--push,上传docker仓。或者可以使用--output指定输出方式。
docker buildx build --platform linux/amd64,linux/arm64 -t buildx.com/base/java-base:openjdk-8-centos7 . --push

来源:https://segmentfault.com/a/1190000021529637

标签:Docker,buildx,镜像,私有仓库
0
投稿

猜你喜欢

  • 六个WordPress实用的评论回复通知插件下载

    2010-03-21 08:40:00
  • 分级防御 针对Linux服务器攻击防范

    2009-09-20 20:04:00
  • 精挑细选网站关键词

    2007-11-29 12:43:00
  • 对找友情链接的一点思考

    2009-01-09 09:02:00
  • 基于Ubuntu 16.04设置固定IP的方法教程

    2023-12-17 07:09:33
  • Linux中增加软路由的两种方法

    2012-02-25 19:51:22
  • 雅虎为什么不愿卖给微软?

    2008-02-11 17:09:00
  • Apache Shiro 框架简介

    2022-04-18 02:27:58
  • VMware中CentOS设置静态IP的方法

    2023-08-14 09:15:05
  • 在校学生如何通过网络赚钱

    2010-05-16 07:36:00
  • 选择合适自己的服务器

    2010-08-15 18:56:00
  • 草根站长需要改变的习惯

    2008-02-17 14:07:00
  • Apache中伪静态Rewrite的使用方法和URL重写规则表达式讲解

    2022-12-27 06:34:37
  • CentOS查询软件包的安装位置

    2023-12-22 07:37:40
  • centos6.5 lamp 环境(使用yum安装方法)

    2022-10-13 03:51:03
  • 虚拟机linux下静态IP的配置方法

    2022-07-16 12:12:25
  • dedecms5.1sp1的TAG重复不显示BUG解决办法

    2009-02-13 18:18:00
  • 基于Unix的Web服务器安全指南

    2009-09-10 12:52:00
  • 消息称谷歌Chrome操作系统本周三正式发布

    2009-11-16 08:18:00
  • Linux下安装RPM和TAR管理软件包的方法

    2008-10-10 11:10:00
  • asp之家 网站运营 m.aspxhome.com