docker image save
| 描述 | 将一个或多个镜像保存到 tar 归档文件(默认流式传输到 STDOUT) |
|---|---|
| 用法 | docker image save [OPTIONS] IMAGE [IMAGE...] |
| 别名 | docker save |
描述
生成一个 tar 格式的仓库到标准输出流。包含所有父层、所有标签 + 版本,或为每个提供的参数指定 `repo:tag`。
选项
| 选项 | 默认值 | 描述 |
|---|---|---|
-o, --output | 写入文件,而不是 STDOUT | |
--platform | API 1.48+ 仅保存给定平台变体。格式为 `os[/arch[/variant]]` (例如,`linux/amd64`) |
示例
创建一个备份,然后可以使用 `docker load`。
$ docker save busybox > busybox.tar
$ ls -sh busybox.tar
2.7M busybox.tar
$ docker save --output busybox.tar busybox
$ ls -sh busybox.tar
2.7M busybox.tar
$ docker save -o fedora-all.tar fedora
$ docker save -o fedora-latest.tar fedora:latest
使用 gzip 将镜像保存为 tar.gz 文件
您可以使用 gzip 保存镜像文件,使备份更小。
$ docker save myimage:latest | gzip > myimage_latest.tar.gz
挑选特定标签
您甚至可以挑选镜像仓库的特定标签。
$ docker save -o ubuntu.tar ubuntu:lucid ubuntu:saucy
保存特定平台 (--platform)
`--platform` 选项允许您指定要保存的镜像平台变体。默认情况下,`docker save` 会保存守护进程镜像存储中存在的所有平台变体。使用 `--platform` 选项指定要保存的镜像平台变体。如果给定平台在本地镜像存储中不存在,则会产生错误。
平台选项采用 os[/arch[/variant]] 格式;例如,linux/amd64 或 linux/arm64/v8。架构和变体是可选的,如果省略,则默认为守护进程的本机架构。
以下示例拉取 `alpine:latest` 镜像的 RISC-V 变体并将其保存到 tar 归档文件。
$ docker pull --platform=linux/riscv64 alpine:latest
latest: Pulling from library/alpine
8c4a05189a5f: Download complete
Digest: sha256:beefdbd8a1da6d2915566fde36db9db0b524eb737fc57cd1367effd16dc0d06d
Status: Downloaded newer image for alpine:latest
docker.io/library/alpine:latest
$ docker image save --platform=linux/riscv64 -o alpine-riscv.tar alpine:latest
$ ls -lh image.tar
-rw------- 1 thajeztah staff 3.9M Oct 7 11:06 alpine-riscv.tar
以下示例尝试保存 `alpine:latest` 在本地镜像存储中不存在的平台变体,导致错误。
$ docker image ls --tree
IMAGE ID DISK USAGE CONTENT SIZE IN USE
alpine:latest beefdbd8a1da 10.6MB 3.37MB
├─ linux/riscv64 80cde017a105 10.6MB 3.37MB
├─ linux/amd64 33735bd63cf8 0B 0B
├─ linux/arm/v6 50f635c8b04d 0B 0B
├─ linux/arm/v7 f2f82d424957 0B 0B
├─ linux/arm64/v8 9cee2b382fe2 0B 0B
├─ linux/386 b3e87f642f5c 0B 0B
├─ linux/ppc64le c7a6800e3dc5 0B 0B
└─ linux/s390x 2b5b26e09ca2 0B 0B
$ docker image save --platform=linux/s390x -o alpine-s390x.tar alpine:latest
Error response from daemon: no suitable export target found for platform linux/s390x