mirror of
				https://github.com/containers/podman.git
				synced 2025-10-20 20:54:45 +08:00 
			
		
		
		
	 9ba52e8ef0
			
		
	
	9ba52e8ef0
	
	
	
		
			
			The goal is to improve errors when users use the wrong transport in certain cases we stutter, in other cases we don't give enough information. Remove stutters when failing to pull remote images, because of lack of support. Fix errors returned by reference.Parse to wrap in image that was being checked. Fixes: https://github.com/containers/podman/issues/7116 Signed-off-by: Daniel J Walsh <dwalsh@redhat.com>
		
			
				
	
	
		
			165 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			165 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| % podman-push(1)
 | |
| 
 | |
| ## NAME
 | |
| podman\-push - Push an image from local storage to elsewhere
 | |
| 
 | |
| ## SYNOPSIS
 | |
| **podman push** [*options*] *image* [*destination*]
 | |
| 
 | |
| **podman image push** [*options*] *image* [*destination*]
 | |
| 
 | |
| ## DESCRIPTION
 | |
| Pushes an image from local storage to a specified destination.
 | |
| Push is mainly used to push images to registries, however **podman push**
 | |
| can be used to save images to tarballs and directories using the following
 | |
| transports: **dir:**, **docker-archive:**, **docker-daemon:** and **oci-archive:**.
 | |
| 
 | |
| ## Image storage
 | |
| Images are pushed from those stored in local image storage.
 | |
| 
 | |
| ## DESTINATION
 | |
| 
 | |
|  The DESTINATION is a location to store container images
 | |
|  The Image "DESTINATION" uses a "transport":"details" format.
 | |
|  If a transport is not given, podman push will attempt to push
 | |
|  to a registry.
 | |
| 
 | |
|  Multiple transports are supported:
 | |
| 
 | |
|   **dir:**_path_
 | |
|   An existing local directory _path_ storing the manifest, layer tarballs and signatures as individual files. This is a non-standardized format, primarily useful for debugging or noninvasive container inspection.
 | |
| 
 | |
|     $ podman push myimage dir:/tmp/myimage
 | |
| 
 | |
|   **docker://**_docker-reference_
 | |
|   An image in a registry implementing the "Docker Registry HTTP API V2". By default, uses the authorization state in `$XDG_RUNTIME_DIR/containers/auth.json`, which is set using `(podman login)`. If the authorization state is not found there, `$HOME/.docker/config.json` is checked, which is set using `(docker login)`.
 | |
| 
 | |
|     $ podman push myimage quay.io/username/myimage
 | |
| 
 | |
|   **docker-archive:**_path_[**:**_docker-reference_]
 | |
|   An image is stored in the `docker save` formatted file.  _docker-reference_ is only used when creating such a file, and it must not contain a digest.
 | |
| 
 | |
|     $ podman push myimage docker-archive:/tmp/myimage
 | |
| 
 | |
|   **docker-daemon:**_docker-reference_
 | |
|   An image in _docker-reference_ format stored in the docker daemon internal storage. _docker-reference_ must contain a tag.
 | |
| 
 | |
|     $ sudo podman push myimage docker-daemon:docker.io/library/myimage:33
 | |
| 
 | |
|   **oci-archive:**_path_**:**_tag_
 | |
|   An image _tag_ in a directory compliant with "Open Container Image Layout Specification" at _path_.
 | |
| 
 | |
|     $ podman push myimage oci-archive:/tmp/myimage
 | |
| 
 | |
| ## OPTIONS
 | |
| 
 | |
| #### **--authfile**=*path*
 | |
| 
 | |
| Path of the authentication file. Default is ${XDG\_RUNTIME\_DIR}/containers/auth.json, which is set using `podman login`.
 | |
| If the authorization state is not found there, $HOME/.docker/config.json is checked, which is set using `docker login`.
 | |
| 
 | |
| Note: You can also override the default path of the authentication file by setting the REGISTRY\_AUTH\_FILE
 | |
| environment variable. `export REGISTRY_AUTH_FILE=path`
 | |
| 
 | |
| #### **--creds**=*[username[:password]]*
 | |
| 
 | |
| The [username[:password]] to use to authenticate with the registry if required.
 | |
| If one or both values are not supplied, a command line prompt will appear and the
 | |
| value can be entered.  The password is entered without echo.
 | |
| 
 | |
| #### **--cert-dir**=*path*
 | |
| 
 | |
| Use certificates at *path* (\*.crt, \*.cert, \*.key) to connect to the registry.
 | |
| Default certificates directory is _/etc/containers/certs.d_. (Not available for remote commands)
 | |
| 
 | |
| #### **--compress**
 | |
| 
 | |
| Compress tarball image layers when pushing to a directory using the 'dir' transport. (default is same compression type, compressed or uncompressed, as source)
 | |
| Note: This flag can only be set when using the **dir** transport
 | |
| 
 | |
| #### **--digestfile** *Digestfile*
 | |
| 
 | |
| After copying the image, write the digest of the resulting image to the file.  (Not available for remote commands)
 | |
| 
 | |
| #### **--disable-content-trust**
 | |
| 
 | |
| This is a Docker specific option to disable image verification to a Docker
 | |
| registry and is not supported by Podman.  This flag is a NOOP and provided
 | |
| solely for scripting compatibility.
 | |
| 
 | |
| #### **--format**, **-f**=*format*
 | |
| 
 | |
| Manifest Type (oci, v2s1, or v2s2) to use when pushing an image to a directory using the 'dir:' transport (default is manifest type of source)
 | |
| Note: This flag can only be set when using the **dir** transport
 | |
| 
 | |
| #### **--quiet**, **-q**
 | |
| 
 | |
| When writing the output image, suppress progress output
 | |
| 
 | |
| #### **--remove-signatures**
 | |
| 
 | |
| Discard any pre-existing signatures in the image
 | |
| 
 | |
| #### **--sign-by**=*key*
 | |
| 
 | |
| Add a signature at the destination using the specified key
 | |
| 
 | |
| #### **--tls-verify**=*true|false*
 | |
| 
 | |
| Require HTTPS and verify certificates when contacting registries (default: true). If explicitly set to true,
 | |
| then TLS verification will be used. If set to false, then TLS verification will not be used. If not specified,
 | |
| TLS verification will be used unless the target registry is listed as an insecure registry in registries.conf.
 | |
| 
 | |
| ## EXAMPLE
 | |
| 
 | |
| This example pushes the image specified by the imageID to a local directory in docker format.
 | |
| 
 | |
|  `# podman push imageID dir:/path/to/image`
 | |
| 
 | |
| This example pushes the image specified by the imageID to a local directory in oci format.
 | |
| 
 | |
|  `# podman push imageID oci-archive:/path/to/layout:image:tag`
 | |
| 
 | |
| This example pushes the image specified by the imageID to a container registry named registry.example.com
 | |
| 
 | |
|  `# podman push imageID docker://registry.example.com/repository:tag`
 | |
| 
 | |
| This example pushes the image specified by the imageID to a container registry named registry.example.com and saves the digest in the specified digestfile.
 | |
| 
 | |
|  `# podman push --digestfile=/tmp/mydigest imageID docker://registry.example.com/repository:tag`
 | |
| 
 | |
| This example pushes the image specified by the imageID and puts it into the local docker container store
 | |
| 
 | |
|  `# podman push imageID docker-daemon:image:tag`
 | |
| 
 | |
| This example pushes the alpine image to umohnani/alpine on dockerhub and reads the creds from
 | |
| the path given to --authfile
 | |
| 
 | |
| ```
 | |
| # podman push --authfile temp-auths/myauths.json alpine docker://docker.io/umohnani/alpine
 | |
| Getting image source signatures
 | |
| Copying blob sha256:5bef08742407efd622d243692b79ba0055383bbce12900324f75e56f589aedb0
 | |
|  4.03 MB / 4.03 MB [========================================================] 1s
 | |
| Copying config sha256:ad4686094d8f0186ec8249fc4917b71faa2c1030d7b5a025c29f26e19d95c156
 | |
|  1.41 KB / 1.41 KB [========================================================] 1s
 | |
| Writing manifest to image destination
 | |
| Storing signatures
 | |
| ```
 | |
| 
 | |
| This example pushes the rhel7 image to rhel7-dir with the "oci" manifest type
 | |
| ```
 | |
| # podman push --format oci registry.access.redhat.com/rhel7 dir:rhel7-dir
 | |
| Getting image source signatures
 | |
| Copying blob sha256:9cadd93b16ff2a0c51ac967ea2abfadfac50cfa3af8b5bf983d89b8f8647f3e4
 | |
|  71.41 MB / 71.41 MB [======================================================] 9s
 | |
| Copying blob sha256:4aa565ad8b7a87248163ce7dba1dd3894821aac97e846b932ff6b8ef9a8a508a
 | |
|  1.21 KB / 1.21 KB [========================================================] 0s
 | |
| Copying config sha256:f1b09a81455c351eaa484b61aacd048ab613c08e4c5d1da80c4c46301b03cf3b
 | |
|  3.01 KB / 3.01 KB [========================================================] 0s
 | |
| Writing manifest to image destination
 | |
| Storing signatures
 | |
| ```
 | |
| 
 | |
| ## SEE ALSO
 | |
| podman(1), podman-pull(1), podman-login(1)
 |