mirror of https://github.com/docker/cli.git
124 lines
5.7 KiB
Markdown
124 lines
5.7 KiB
Markdown
# push
|
|
|
|
<!---MARKER_GEN_START-->
|
|
Upload an image to a registry
|
|
|
|
### Aliases
|
|
|
|
`docker image push`, `docker push`
|
|
|
|
### Options
|
|
|
|
| Name | Type | Default | Description |
|
|
|:---------------------------------------------|:---------|:--------|:-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
|
| [`-a`](#all-tags), [`--all-tags`](#all-tags) | `bool` | | Push all tags of an image to the repository |
|
|
| `--disable-content-trust` | `bool` | `true` | Skip image signing |
|
|
| `--platform` | `string` | | Push a platform-specific manifest as a single-platform image to the registry.<br>Image index won't be pushed, meaning that other manifests, including attestations won't be preserved.<br>'os[/arch[/variant]]': Explicit platform (eg. linux/amd64) |
|
|
| `-q`, `--quiet` | `bool` | | Suppress verbose output |
|
|
|
|
|
|
<!---MARKER_GEN_END-->
|
|
|
|
## Description
|
|
|
|
Use `docker image push` to share your images to the [Docker Hub](https://hub.docker.com)
|
|
registry or to a self-hosted one.
|
|
|
|
Refer to the [`docker image tag`](image_tag.md) reference for more information
|
|
about valid image and tag names.
|
|
|
|
Killing the `docker image push` process, for example by pressing `CTRL-c` while it is
|
|
running in a terminal, terminates the push operation.
|
|
|
|
Progress bars are shown during docker push, which show the uncompressed size.
|
|
The actual amount of data that's pushed will be compressed before sending, so
|
|
the uploaded size will not be reflected by the progress bar.
|
|
|
|
Registry credentials are managed by [docker login](login.md).
|
|
|
|
### Concurrent uploads
|
|
|
|
By default the Docker daemon will push five layers of an image at a time.
|
|
If you are on a low bandwidth connection this may cause timeout issues and you may want to lower
|
|
this via the `--max-concurrent-uploads` daemon option. See the
|
|
[daemon documentation](https://docs.docker.com/reference/cli/dockerd/) for more details.
|
|
|
|
## Examples
|
|
|
|
### Push a new image to a registry
|
|
|
|
First save the new image by finding the container ID (using [`docker container
|
|
ls`](container_ls.md)) and then committing it to a new image name. Note that
|
|
only `a-z0-9-_.` are allowed when naming images:
|
|
|
|
```console
|
|
$ docker container commit c16378f943fe rhel-httpd:latest
|
|
```
|
|
|
|
Now, push the image to the registry using the image ID. In this example the
|
|
registry is on host named `registry-host` and listening on port `5000`. To do
|
|
this, tag the image with the host name or IP address, and the port of the
|
|
registry:
|
|
|
|
```console
|
|
$ docker image tag rhel-httpd:latest registry-host:5000/myadmin/rhel-httpd:latest
|
|
|
|
$ docker image push registry-host:5000/myadmin/rhel-httpd:latest
|
|
```
|
|
|
|
Check that this worked by running:
|
|
|
|
```console
|
|
$ docker image ls
|
|
```
|
|
|
|
You should see both `rhel-httpd` and `registry-host:5000/myadmin/rhel-httpd`
|
|
listed.
|
|
|
|
### <a name="all-tags"></a> Push all tags of an image (-a, --all-tags)
|
|
|
|
Use the `-a` (or `--all-tags`) option to push all tags of a local image.
|
|
|
|
The following example creates multiple tags for an image, and pushes all those
|
|
tags to Docker Hub.
|
|
|
|
|
|
```console
|
|
$ docker image tag myimage registry-host:5000/myname/myimage:latest
|
|
$ docker image tag myimage registry-host:5000/myname/myimage:v1.0.1
|
|
$ docker image tag myimage registry-host:5000/myname/myimage:v1.0
|
|
$ docker image tag myimage registry-host:5000/myname/myimage:v1
|
|
```
|
|
|
|
The image is now tagged under multiple names:
|
|
|
|
```console
|
|
$ docker image ls
|
|
|
|
REPOSITORY TAG IMAGE ID CREATED SIZE
|
|
myimage latest 6d5fcfe5ff17 2 hours ago 1.22MB
|
|
registry-host:5000/myname/myimage latest 6d5fcfe5ff17 2 hours ago 1.22MB
|
|
registry-host:5000/myname/myimage v1 6d5fcfe5ff17 2 hours ago 1.22MB
|
|
registry-host:5000/myname/myimage v1.0 6d5fcfe5ff17 2 hours ago 1.22MB
|
|
registry-host:5000/myname/myimage v1.0.1 6d5fcfe5ff17 2 hours ago 1.22MB
|
|
```
|
|
|
|
When pushing with the `--all-tags` option, all tags of the `registry-host:5000/myname/myimage`
|
|
image are pushed:
|
|
|
|
|
|
```console
|
|
$ docker image push --all-tags registry-host:5000/myname/myimage
|
|
|
|
The push refers to repository [registry-host:5000/myname/myimage]
|
|
195be5f8be1d: Pushed
|
|
latest: digest: sha256:edafc0a0fb057813850d1ba44014914ca02d671ae247107ca70c94db686e7de6 size: 4527
|
|
195be5f8be1d: Layer already exists
|
|
v1: digest: sha256:edafc0a0fb057813850d1ba44014914ca02d671ae247107ca70c94db686e7de6 size: 4527
|
|
195be5f8be1d: Layer already exists
|
|
v1.0: digest: sha256:edafc0a0fb057813850d1ba44014914ca02d671ae247107ca70c94db686e7de6 size: 4527
|
|
195be5f8be1d: Layer already exists
|
|
v1.0.1: digest: sha256:edafc0a0fb057813850d1ba44014914ca02d671ae247107ca70c94db686e7de6 size: 4527
|
|
```
|
|
|