自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用 Docker Buildx 構(gòu)建多種系統(tǒng)架構(gòu)鏡像

云計(jì)算
Docker Buildx 是一個(gè) docker CLI 插件,其擴(kuò)展了 docker 命令,支持 Moby BuildKit 提供的功能。提供了與 docker build 相同的用戶體驗(yàn),并增加了許多新功能。

[[418928]]

1. 工具說(shuō)明

  • 安裝 Docker >= 19.03: 該 Docker 版本包含 buildx。
  • 安裝 buildx: https://github.com/docker/buildx#in。
  • Linux kernel >= 4.8: 自該Linux內(nèi)核版本 binfmt_misc 支持 fix-binary (F) flag。fix_binary 標(biāo)志允許內(nèi)核在容器或chroot內(nèi)使用binfmt_misc注冊(cè)的二進(jìn)制格式處理程序,即使該處理程序二進(jìn)制文件不是該容器或chroot內(nèi)可見(jiàn)的文件系統(tǒng)的一部分。

Docker Buildx 是一個(gè) docker CLI 插件,其擴(kuò)展了 docker 命令,支持 Moby BuildKit 提供的功能。提供了與 docker build 相同的用戶體驗(yàn),并增加了許多新功能。

BuildKit 是下一代的鏡像構(gòu)建組件,主要特點(diǎn)有很多,本文主要使用其可以編譯多種系統(tǒng)架構(gòu)的特性。

網(wǎng)址:https://github.com/moby/buildkit

需要注意的是,該功能僅適用于 Docker v19.03+ 版本。

本文將講解如何使用 Buildx 構(gòu)建多種系統(tǒng)架構(gòu)的鏡像。

在開(kāi)始之前,已經(jīng)默認(rèn)你在 Linux 系統(tǒng)(各大發(fā)行版)下安裝好了 64 位的 Docker。

在寫(xiě)本文時(shí),使用的Docker版本號(hào)是 19.03.11。

  1. root@i-3uavns2y:~# docker version 
  2. Client: Docker Engine - Community 
  3. Version:           19.03.11 
  4.  API version:       1.40 
  5. Go version:        go1.13.10 
  6. Git commit:        42e35e61f3 
  7. Built:             Mon Jun  1 09:13:48 2020 
  8.  OS/Arch:           linux/amd64 
  9. Experimental:      true 
  10. Server: Docker Engine - Community 
  11. Engine: 
  12.   Version:          19.03.11 
  13.   API version:      1.40 (minimum version 1.12) 
  14.   Go version:       go1.13.10 
  15.   Git commit:       42e35e61f3 
  16.   Built:            Mon Jun  1 09:12:26 2020 
  17.   OS/Arch:          linux/amd64 
  18.   Experimental:     false 
  19.  containerd: 
  20.   Version:          1.2.13 
  21.   GitCommit:        7ad184331fa3e55e52b890ea95e65ba581ae3429 
  22.  runc: 
  23.   Version:          1.0.0-rc10 
  24.   GitCommit:        dc9208a3303feef5b3839f4323d9beb36df0a9dd 
  25.  docker-init: 
  26.   Version:          0.18.0 
  27.   GitCommit:        fec3683 
  28.   root@i-3uavns2y:~# uname -a 
  29. Linux i-3uavns2y 4.15.0-55-generic #60-Ubuntu SMP Tue Jul 2 18:22:20 UTC 2019 x86_64 x86_64 x86_64 GNU/Linux 

2. 運(yùn)行原理

Buildx 本質(zhì)上調(diào)用了 buildkit 的 api,構(gòu)建是在 buildkit 的環(huán)境中進(jìn)行的。是否支持多架構(gòu),取決于 buildkit 的環(huán)境,如果需要 buildkit 支持多架構(gòu),需要在宿主機(jī)執(zhí)行。(當(dāng)然這個(gè)不是必須的,按構(gòu)建的需求進(jìn)行控制)

BuildKit 旨在為多個(gè)平臺(tái)進(jìn)行構(gòu)建,而不僅適用于調(diào)用構(gòu)建的用戶碰巧運(yùn)行的體系結(jié)構(gòu)和操作系統(tǒng)。

調(diào)用構(gòu)建時(shí),您可以設(shè)置--platform標(biāo)志以指定構(gòu)建輸出的目標(biāo)平臺(tái)(例如linux/amd64,linux/arm64、 或 darwin/amd64)。

當(dāng)當(dāng)前構(gòu)建器實(shí)例由docker-container或 kubernetes驅(qū)動(dòng)程序支持時(shí),您可以一起指定多個(gè)平臺(tái)。在這種情況下,它會(huì)構(gòu)建一個(gè)清單列表,其中包含所有指定架構(gòu)的類(lèi)型。當(dāng)你在docker run or 中使用這個(gè)鏡像時(shí)docker service,Docker 會(huì)根據(jù)節(jié)點(diǎn)的平臺(tái)選擇正確的鏡像。

您可以使用 Buildx 和 Dockerfiles 支持的三種不同策略構(gòu)建多平臺(tái)鏡像:

  • 在內(nèi)核中使用 QEMU 仿真支持
  • 使用相同的構(gòu)建器實(shí)例在多個(gè)本機(jī)節(jié)點(diǎn)上構(gòu)建
  • 使用 Dockerfile 中的一個(gè)階段交叉編譯到不同的架構(gòu)

如果您的節(jié)點(diǎn)已經(jīng)支持 QEMU,那么 QEMU 是最簡(jiǎn)單的入門(mén)方式(例如,如果您使用的是 Docker Desktop)。它不需要對(duì) Dockerfile 進(jìn)行任何更改,并且 BuildKit 會(huì)自動(dòng)檢測(cè)可用的二級(jí)架構(gòu)。當(dāng) BuildKit 需要為不同的架構(gòu)運(yùn)行二進(jìn)制文件時(shí),它會(huì)通過(guò)在binfmt_misc 處理程序中注冊(cè)的二進(jìn)制文件自動(dòng)加載它。

要使binfmt_misc在主機(jī)操作系統(tǒng)上注冊(cè)的 QEMU 二進(jìn)制文件在容器內(nèi)透明地工作,它們必須使用該fix_binary 標(biāo)志進(jìn)行注冊(cè)。這需要內(nèi)核 >= 4.8 和 binfmt-support >= 2.1.7。您可以通過(guò)檢查在/proc/sys/fs/binfmt_misc/qemu-*是否有內(nèi)容來(lái)檢查是否正確注冊(cè)。雖然 Docker Desktop 預(yù)先配置了binfmt_misc對(duì)其他平臺(tái)的支持,但對(duì)于其他安裝,它可能需要使用tonistiigi/binfmt 鏡像進(jìn)行安裝。

  1. root@i-tpmja312:~# docker run --privileged --rm tonistiigi/binfmt --install all 
  2. root@i-tpmja312:~# ls /proc/sys/fs/binfmt_misc/qemu-* 
  3. /proc/sys/fs/binfmt_misc/qemu-aarch64   /proc/sys/fs/binfmt_misc/qemu-ppc64le 
  4. /proc/sys/fs/binfmt_misc/qemu-arm       /proc/sys/fs/binfmt_misc/qemu-riscv64 
  5. /proc/sys/fs/binfmt_misc/qemu-mips64    /proc/sys/fs/binfmt_misc/qemu-s390x 
  6. /proc/sys/fs/binfmt_misc/qemu-mips64el 

使用多個(gè)原生節(jié)點(diǎn)可以更好地支持 QEMU 無(wú)法處理的更復(fù)雜的情況,并且通常具有更好的性能。您可以使用該--append標(biāo)志向構(gòu)建器實(shí)例添加其他節(jié)點(diǎn)。

2. 啟用 Buildx

Docker在19.03引入了一個(gè)新的特性,使得Docker可以構(gòu)建不同CPU體系結(jié)構(gòu)的鏡像,比如ARM鏡像,這是不必引入模擬器的情況下,Docker自身所提供的原生統(tǒng)一構(gòu)建機(jī)制,但是使用時(shí)需要進(jìn)行設(shè)定才能進(jìn)行使用。(從 v20.10 版本開(kāi)始,Docker CLI 所有實(shí)驗(yàn)特性的命令均默認(rèn)開(kāi)啟,無(wú)需再進(jìn)行配置或設(shè)置系統(tǒng)環(huán)境變量。)

buildx 命令屬于實(shí)驗(yàn)特性,因此首先需要開(kāi)啟該特性。

  • 問(wèn)題現(xiàn)象

直接使用時(shí)可能會(huì)出現(xiàn)如下問(wèn)題,因?yàn)闆](méi)開(kāi)啟實(shí)驗(yàn)特性

  1. root@i-3uavns2y:~# docker buildx version 
  2. docker: 'buildx' is not a docker command. 
  3. See 'docker --help' 
  • 永久開(kāi)啟 dockerd 的實(shí)驗(yàn)特性

編輯 ~/.docker/config.json 文件,新增如下內(nèi)容(以下的演示適用于事先不存在 .docker 目錄的情況下),使用 docker version 命令查看版本信息,配置生效后可以看到 Server: Docker Engine 中有 Experimental: true :

  1. root@i-3uavns2y:~# mkdir ~/.docker 
  2. root@i-3uavns2y:~# cat > ~/.docker/config.json <<EOF 
  3. "experimental""enabled" 
  4. EOF 
  5. root@i-3uavns2y:~# docker buildx version 
  6. github.com/docker/buildx v0.3.1-tp-docker 6db68d029599c6710a32aa7adcba8e5a344795a7 
  • 臨時(shí)開(kāi)啟

Linux/macOS 下或者通過(guò)設(shè)置環(huán)境變量的方式(不推薦):

  1. $ export DOCKER_CLI_EXPERIMENTAL=enabled 
  2. $ docker buildx version 
  3. github.com/docker/buildx v0.3.1-tp-docker 6db68d029599c6710a32aa7adcba8e5a344795a7 

3. 新建 builder 實(shí)例

在 Docker 19.03+ 版本中可以使用 docker buildx build 命令使用 BuildKit 構(gòu)建鏡像。該命令支持 --platform 參數(shù)可以同時(shí)構(gòu)建支持多種系統(tǒng)架構(gòu)的 Docker 鏡像,大大簡(jiǎn)化了構(gòu)建步驟。

Docker 在 Linux 系統(tǒng)架構(gòu)下是不支持 arm 架構(gòu)鏡像,因此我們可以運(yùn)行一個(gè)新的容器讓其支持該特性,Docker 桌面版則無(wú)需進(jìn)行此項(xiàng)設(shè)置(mac系統(tǒng))。

在內(nèi)核中使用 QEMU 仿真支持來(lái)進(jìn)行多架構(gòu)鏡像構(gòu)建:

  1. # 安裝模擬器(用于多平臺(tái)鏡像構(gòu)建) 
  2. $ docker run --rm --privileged tonistiigi/binfmt:latest --install all 

注:docker/binfmt 可以參考網(wǎng)址:https://hub.docker.com/r/docker/binfmt/tags 獲取最新鏡像。

由于 Docker 默認(rèn)的 builder 實(shí)例不支持同時(shí)指定多個(gè) --platform,我們必須首先創(chuàng)建一個(gè)新的 builder 實(shí)例。同時(shí)由于國(guó)內(nèi)拉取鏡像較緩慢,我們可以使用配置了 鏡像加速地址 dockerpracticesig/buildkit:master 鏡像替換官方鏡像。

如果你有私有的鏡像加速器,可以基于 https://github.com/docker-practice/buildx 構(gòu)建自己的 buildkit 鏡像并使用它。

  1. # 適用于國(guó)內(nèi)環(huán)境 
  2. root@i-3uavns2y:~# docker buildx create --use --name=mybuilder-cn --driver docker-container --driver-opt image=dockerpracticesig/buildkit:master 
  3.  
  4. # 適用于騰訊云環(huán)境(騰訊云主機(jī)、coding.net 持續(xù)集成) 
  5. root@i-3uavns2y:~# docker buildx create --use --name=mybuilder-cn --driver docker-container --driver-opt image=dockerpracticesig/buildkit:master-tencent 
  6. # 使用默認(rèn)鏡像 
  7. root@i-3uavns2y:~# docker buildx create --name mybuilder --driver docker-container 
  8.  
  9. # 使用新創(chuàng)建好的 builder 實(shí)例 
  10. root@i-3uavns2y:~# docker buildx use mybuilder 

查看已有的 builder 實(shí)例:

  1. root@i-tpmja312:~# docker buildx ls 
  2. NAME/NODE    DRIVER/ENDPOINT             STATUS   PLATFORMS 
  3. mybuilder *  docker-container 
  4.   mybuilder0 unix:///var/run/docker.sock inactive 
  5. default      docker 
  6.   default    default                     running  linux/amd64, linux/386 

4. 新建 Dockerfile 文件

要想構(gòu)建多種系統(tǒng)架構(gòu)的鏡像,還需要一個(gè)支持的 Dockerfile 文件,這里面多架構(gòu)鏡像最主要的就是基礎(chǔ)鏡像和安裝的軟件都需要支持多架構(gòu)。

以下是一個(gè)示例的 Dockerfile 文件,該 Dockerfile 文件內(nèi)容如下:

  1. mkdir ~/demo 
  2. cd ~/demo 
  3. cat > Dockerfile <<EOF 
  4. FROM --platform=$TARGETPLATFORM alpine 
  5. RUN uname -a > /os.txt 
  6. CMD cat /os.txt 
  7. EOF 

$TARGETPLATFORM 是內(nèi)置變量,由 --platform 參數(shù)來(lái)指定其值。

由于是基于 alpine 的鏡像來(lái)制作的,而 alpine 是支持以下 7 種系統(tǒng)架構(gòu)的,因此我們制作的鏡像也就跟著支持這 7 種系統(tǒng)架構(gòu)。

  1. linux/amd64, linux/arm/v6, linux/arm/v7, linux/arm64/v8, linux/386, linux/ppc64le, linux/s390x 

更友好一點(diǎn)的架構(gòu)名稱(chēng)如下:

  1. amd64, arm32v6, arm32v7, arm64v8, i386, ppc64le, s390x 

這里穿插一句吐槽,簡(jiǎn)單統(tǒng)計(jì)了一下,ARM 的系統(tǒng)架構(gòu)有如下各種簡(jiǎn)稱(chēng):

  1. arm64, armv8l, arm64v8, aarch64 
  2. arm, arm32, arm32v7, armv7, armv7l, armhf 
  3. arm32v6, armv6, armv6l, arm32v5, armv5,  armv5l, armel, aarch32 

而對(duì)比 Intel 和 AMD 的就簡(jiǎn)單多了:

  1. x86, 386, i386, i686 
  2. x86_64, x64, amd64 

5. 構(gòu)建鏡像

docker buildx build 的具體參數(shù)含義,參考下面的官方文檔:https://docs.docker.com/engine/reference/commandline/buildx_build/ 。

使用 $ docker buildx build 命令構(gòu)建鏡像,注意將 myusername 替換為自己的 Docker Hub 用戶名。--push 參數(shù)表示將構(gòu)建好的鏡像推送到 Docker 倉(cāng)庫(kù)。再來(lái)構(gòu)建一個(gè)多系統(tǒng)架構(gòu)鏡像,并將構(gòu)建好的鏡像推送到 Docker 倉(cāng)庫(kù)(也就是 hub.docker.com)。在此操作之前,你需要事先注冊(cè)一個(gè)賬號(hào)(演示過(guò)程省略),并登錄。

登錄命令如下:

  1. root@i-tpmja312:~/demo# docker login 

輸入你的用戶名和密碼即可登錄。

注意,以下演示的命令中 tag 的前面是我的用戶名 doubledong,如果你想制作自己的鏡像,請(qǐng)自行替換為你自己的用戶名。

使用 --push 參數(shù)構(gòu)建好的鏡像推送到 Docker 倉(cāng)庫(kù)。

構(gòu)建命令如下:

在本地構(gòu)建支持 7 種 platform 的鏡像

  1. root@i-tpmja312:~/demo# docker buildx build --platform linux/amd64,linux/arm/v6,linux/arm/v7,linux/arm64/v8,linux/386,linux/ppc64le,linux/s390x -t doubledong/hello . --push 
  2.  
  3. # 查看鏡像信息 
  4. root@i-tpmja312:~/demo# docker buildx imagetools inspect doubledong/hello 
  5. Name:      docker.io/doubledong/hello:latest 
  6. MediaType: application/vnd.docker.distribution.manifest.list.v2+json 
  7. Digest:    sha256:7fd51fbd9f5a478c751ab2138d87341da7937b82bbf2362b23d474727b2c7234 
  8.  
  9. Manifests: 
  10.   Name:      docker.io/doubledong/hello:latest@sha256:564098e26174ef2142fbb8bf21d3e57bc2cb31e31933e6e23c5ee8a7bea05219 
  11.   MediaType: application/vnd.docker.distribution.manifest.v2+json 
  12.   Platform:  linux/amd64 
  13.  
  14.   Name:      docker.io/doubledong/hello:latest@sha256:d378c84bcd8bce4b5d771be692bd251a8cb3bbaca9f203d20a5da6989d42c614 
  15.   MediaType: application/vnd.docker.distribution.manifest.v2+json 
  16.   Platform:  linux/arm/v6 
  17.  
  18.   Name:      docker.io/doubledong/hello:latest@sha256:1968399b3651bbcb0dc6218e6dfcb261995723decf39b9c80327624409158ff5 
  19.   MediaType: application/vnd.docker.distribution.manifest.v2+json 
  20.   Platform:  linux/arm/v7 
  21.  
  22.   Name:      docker.io/doubledong/hello:latest@sha256:62ac2af6e39ab10e77d83114931ff1abe449c30a86d0bf590d4bbf71836dcec1 
  23.   MediaType: application/vnd.docker.distribution.manifest.v2+json 
  24.   Platform:  linux/arm64 
  25.  
  26.   Name:      docker.io/doubledong/hello:latest@sha256:3ef9adac67717528ca95f89c184830aa072da155fc17e2a7e95dd9433d9aab51 
  27.   MediaType: application/vnd.docker.distribution.manifest.v2+json 
  28.   Platform:  linux/386 
  29.  
  30.   Name:      docker.io/doubledong/hello:latest@sha256:67e4c3e5c7eca8af5909373446e9e5fa6d1083223b3766bb8e9e6f41c01ca43b 
  31.   MediaType: application/vnd.docker.distribution.manifest.v2+json 
  32.   Platform:  linux/ppc64le 
  33.  
  34.   Name:      docker.io/doubledong/hello:latest@sha256:f3dc2d058e4915a61281d945ae92e77b44e2b81a601c63470ce1912e4e29c53e 
  35.   MediaType: application/vnd.docker.distribution.manifest.v2+json 
  36.   Platform:  linux/s390x 

.命令執(zhí)行成功后,你就會(huì)在 Docker Hub 看到你上傳的鏡像啦。示例圖如下:

做完上面的那一步,實(shí)際上是把構(gòu)建好的鏡像放在了本地路徑下,此時(shí)我們?cè)賮?lái)查看一下已有的 builder 實(shí)例。

  1. root@i-tpmja312:~/demo# docker buildx ls 
  2. NAME/NODE    DRIVER/ENDPOINT             STATUS  PLATFORMS 
  3. mybuilder *  docker-container 
  4.   mybuilder0 unix:///var/run/docker.sock running linux/amd64, linux/arm64, linux/riscv64, linux/ppc64le, linux/s390x, linux/386, linux/mips64le, linux/mips64, linux/arm/v7, linux/arm/v6 
  5. default      docker 
  6.   default    default                     running linux/amd64, linux/386 

你會(huì)發(fā)現(xiàn) mybuilder 下存在 8 種支持的架構(gòu)(riscv64 目前還用不上,但是已經(jīng)支持)。

此時(shí)查看一下 docker image 的運(yùn)行情況,會(huì)發(fā)現(xiàn)存在一個(gè)名為 buildx_buildkit_mybuilder0 的容器在運(yùn)行。

這是剛才在本地構(gòu)建時(shí),自動(dòng)創(chuàng)建的,切記不要將其停止,也不要?jiǎng)h除。

  1. root@i-tpmja312:~/demo# docker ps -as|grep buildx_buildkit 
  2. e274b21faea2        moby/buildkit:buildx-stable-1      "buildkitd"              7 minutes ago       Up 7 minutes                                         buildx_buildkit_mybuilder0                                                                                                                                0B (virtual 144MB) 

6. 寫(xiě)在最后

在制作多系統(tǒng)架構(gòu)的 Docker 鏡像時(shí),建議使用 CPU 比較強(qiáng)或者多核心的 vps 來(lái)構(gòu)建,否則會(huì)非常耗時(shí),本篇文章主要講的是手動(dòng)進(jìn)行多架構(gòu)鏡像的構(gòu)建,也可以是用cicd工具來(lái)自動(dòng)化進(jìn)行構(gòu)建,后續(xù)文章進(jìn)行說(shuō)明

參考鏈接:

https://yeasy.gitbook.io/docker_practice/image/manifest

https://github.com/docker/buildx#installing

本文轉(zhuǎn)載自微信公眾號(hào)「 運(yùn)維開(kāi)發(fā)故事」

責(zé)任編輯:姜華 來(lái)源: 運(yùn)維開(kāi)發(fā)故事
相關(guān)推薦

2021-06-17 09:50:45

Docker Buil系統(tǒng)架構(gòu)Linux

2021-09-29 08:52:31

Ventoy 開(kāi)源工具U盤(pán)

2024-02-20 08:08:43

2017-03-24 09:24:21

HarborDocker鏡像倉(cāng)庫(kù)

2020-11-12 07:51:05

DockerSpring Boot應(yīng)用

2022-09-06 10:39:38

Docker鏡像構(gòu)建

2017-11-13 17:17:11

Docker鏡像Go

2021-12-17 14:49:44

Linuxinxi 命令系統(tǒng)信息

2019-10-30 12:00:02

Ansible容器與云容器鏡像

2019-10-11 10:44:30

Go語(yǔ)言數(shù)據(jù)庫(kù)軟件

2009-12-25 11:04:31

Fedora DNS

2024-05-06 08:07:01

Spring項(xiàng)目Java

2023-12-04 16:18:30

2024-01-16 09:39:13

Docker系統(tǒng)

2010-01-11 17:08:49

Fedora 10安裝

2020-08-24 07:00:00

服務(wù)器Docker技術(shù)

2023-11-28 13:17:21

mkosiRHELRHEL UBI

2021-02-23 15:05:55

Docker鏡像開(kāi)發(fā)

2021-12-07 06:02:15

Redis Docker運(yùn)維

2022-07-15 14:54:00

DockerLinux技巧
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)