mirror of
https://github.com/yeasy/docker_practice.git
synced 2024-11-16 19:43:41 +00:00
eb274b16f6
Signed-off-by: Kang HuaiShuai <khs1994@khs1994.com>
63 lines
2.0 KiB
Go
63 lines
2.0 KiB
Go
# 使用 buildx 构建多种系统架构支持的 Docker 镜像
|
||
|
||
在之前的版本中构建多种系统架构支持的 Docker 镜像,要想使用统一的名字必须使用 [`$ docker manifest`](../image/manifest.md) 命令。
|
||
|
||
在 Docker 19.03+ 版本中可以使用 `$ docker buildx build` 命令使用 `BuildKit` 构建镜像。该命令支持 `--platform` 参数可以同时构建支持多种系统架构的 Docker 镜像,大大简化了构建步骤。
|
||
|
||
## 新建 `builder` 实例
|
||
|
||
Docker for Linux 不支持构建 `arm` 架构镜像,我们可以运行一个新的容器让其支持该特性,Docker 桌面版无需进行此项设置。
|
||
|
||
```bash
|
||
$ docker run --rm --privileged docker/binfmt:820fdd95a9972a5308930a2bdfb8573dd4447ad3
|
||
```
|
||
|
||
由于 Docker 默认的 `builder` 实例不支持同时指定多个 `--platform`,我们必须首先创建一个新的 `builder` 实例。
|
||
|
||
```bash
|
||
# $ docker buildx create --name mybuilder
|
||
|
||
$ docker buildx create --name=mybuilder --driver docker-container --driver-opt image=dockerpracticesig/buildkit:master
|
||
|
||
$ docker buildx use mybuilder
|
||
```
|
||
|
||
## 构建镜像
|
||
|
||
新建 Dockerfile 文件。
|
||
|
||
```docker
|
||
FROM --platform=$TARGETPLATFORM alpine
|
||
|
||
RUN uname -a > /os.txt
|
||
|
||
CMD cat /os.txt
|
||
```
|
||
|
||
使用 `$ docker buildx build` 命令构建镜像,注意将 `myusername` 替换为自己的 Docker Hub 用户名。
|
||
|
||
`--push` 参数表示将构建好的镜像推送到 Docker 仓库。
|
||
|
||
```bash
|
||
$ docker buildx build --platform linux/arm,linux/arm64,linux/amd64 -t myusername/hello . --push
|
||
|
||
# 查看镜像信息
|
||
$ docker buildx imagetools inspect myusername/hello
|
||
```
|
||
|
||
在不同架构运行该镜像,可以得到该架构的信息。
|
||
|
||
```bash
|
||
# arm
|
||
$ docker run -it --rm myusername/hello
|
||
Linux buildkitsandbox 4.9.125-linuxkit #1 SMP Fri Sep 7 08:20:28 UTC 2018 armv7l Linux
|
||
|
||
# arm64
|
||
$ docker run -it --rm myusername/hello
|
||
Linux buildkitsandbox 4.9.125-linuxkit #1 SMP Fri Sep 7 08:20:28 UTC 2018 aarch64 Linux
|
||
|
||
# amd64
|
||
$ docker run -it --rm myusername/hello
|
||
Linux buildkitsandbox 4.9.125-linuxkit #1 SMP Fri Sep 7 08:20:28 UTC 2018 x86_64 Linux
|
||
```
|