2020-08-19 19:46:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[](https://github.com/docker/build-push-action/releases/latest)
							 
						 
					
						
							
								
									
										
										
										
											2020-09-08 22:03:42 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[](https://github.com/marketplace/actions/build-and-push-docker-images)
							 
						 
					
						
							
								
									
										
										
										
											2020-08-19 19:46:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[](https://github.com/docker/build-push-action/actions?workflow=ci)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[](https://github.com/docker/build-push-action/actions?workflow=test)
							 
						 
					
						
							
								
									
										
										
										
											2020-09-08 21:34:53 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[](https://codecov.io/gh/docker/build-push-action)
							 
						 
					
						
							
								
									
										
										
										
											2020-08-19 19:46:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-09-29 00:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Upgrade from v1
  
						 
					
						
							
								
									
										
										
										
											2020-09-28 23:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								`v2`  of this action includes significant updates and now uses Docker [Buildx ](https://github.com/docker/buildx ). It's 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								also rewritten as a [typescript-action ](https://github.com/actions/typescript-action/ ) to be as close as possible
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								of the [GitHub Runner ](https://github.com/actions/virtual-environments ) during its execution.
							 
						 
					
						
							
								
									
										
										
										
											2020-09-28 23:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[Upgrade notes ](UPGRADE.md ) with many [usage examples ](#advanced-usage ) have been added to handle most use cases but
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`v1`  is still available through [`releases/v1` branch ](https://github.com/docker/build-push-action/tree/releases/v1 ). 
						 
					
						
							
								
									
										
										
										
											2020-09-28 23:08:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## About
  
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								GitHub Action to build and push Docker images with [Buildx ](https://github.com/docker/buildx ) with full support of the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								features provided by [Moby BuildKit ](https://github.com/moby/buildkit ) builder toolkit. This includes multi-platform
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								build, secrets, remote cache, etc. and different builder deployment/namespacing options.
							 
						 
					
						
							
								
									
										
										
										
											2020-03-16 15:13:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-29 14:10:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  :bulb: See also:
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  * [login](https://github.com/docker/login-action) action
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  * [setup-buildx](https://github.com/docker/setup-buildx-action) action
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  * [setup-qemu](https://github.com/docker/setup-qemu-action) action
  
						 
					
						
							
								
									
										
										
										
											2020-08-19 19:35:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-19 19:46:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								___
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  [Usage ](#usage ) 
						 
					
						
							
								
									
										
										
										
											2020-09-02 08:07:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  [Git context ](#git-context )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [Path context ](#path-context )
							 
						 
					
						
							
								
									
										
										
										
											2020-09-12 18:40:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  [Advanced usage ](#advanced-usage ) 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  [Multi-platform image ](docs/advanced/multi-platform.md )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [Secrets ](docs/advanced/secrets.md )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [Isolated builders ](docs/advanced/isolated-builders.md )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [Push to multi-registries ](docs/advanced/push-multi-registries.md )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [Cache ](docs/advanced/cache.md )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  [Registry cache ](docs/advanced/cache.md#registry-cache )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    *  [GitHub cache ](docs/advanced/cache.md#github-cache )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [Local registry ](docs/advanced/local-registry.md )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [Export image to Docker ](docs/advanced/export-docker.md )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [Handle tags and labels ](docs/advanced/tags-labels.md )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [Update DockerHub repo description ](docs/advanced/dockerhub-desc.md )
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  [Customizing ](#customizing ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [inputs ](#inputs )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [outputs ](#outputs )
							 
						 
					
						
							
								
									
										
										
										
											2020-09-21 16:22:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  [Troubleshooting ](#troubleshooting ) 
						 
					
						
							
								
									
										
										
										
											2020-08-20 15:25:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  [Keep up-to-date with GitHub Dependabot ](#keep-up-to-date-with-github-dependabot ) 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  [Limitation ](#limitation ) 
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Usage
  
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								By default, this action uses the [Git context ](#git-context ) so you don't need to use the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[`actions/checkout` ](https://github.com/actions/checkout/ ) action to checkout the repository because this will be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								done directly by buildkit. The git reference will be based on the [event that triggered your workflow ](https://docs.github.com/en/actions/reference/events-that-trigger-workflows )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and will result in the following context: `https://github.com/<owner>/<repo>.git#<ref>` .
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Be careful because **any file mutation in the steps that precede the build step will be ignored**  since
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the context is based on the git reference. However, you can use the [Path context ](#path-context ) using the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								[`context` input ](#inputs ) alongside the [`actions/checkout` ](https://github.com/actions/checkout/ ) action to remove
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								this restriction.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In the examples below we are using 3 other actions:
							 
						 
					
						
							
								
									
										
										
										
											2020-09-02 08:07:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  [`setup-buildx` ](https://github.com/docker/setup-buildx-action ) action will create and boot a builder using by  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								default the `docker-container`  [builder driver ](https://github.com/docker/buildx#--driver-driver ). This is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**not required but recommended** using it to be able to build multi-platform images, export cache, etc.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  [`setup-qemu` ](https://github.com/docker/setup-qemu-action ) action can be useful if you want 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								to add emulation support with QEMU to be able to build against more platforms. 
							 
						 
					
						
							
								
									
										
										
										
											2021-02-24 22:16:50 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  [`login` ](https://github.com/docker/login-action ) action will take care to log in against a Docker registry. 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Git context
  
						 
					
						
							
								
									
										
										
										
											2020-09-12 18:40:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-09-22 18:49:18 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								name: ci
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								on:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  push:
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    branches:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  'master'
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								jobs:
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  docker:
							 
						 
					
						
							
								
									
										
										
										
											2020-08-17 20:18:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    runs-on: ubuntu-latest
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    steps:
							 
						 
					
						
							
								
									
										
										
										
											2020-09-05 03:18:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name: Set up QEMU
							 
						 
					
						
							
								
									
										
										
										
											2020-09-08 22:32:40 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        uses: docker/setup-qemu-action@v1
							 
						 
					
						
							
								
									
										
										
										
											2020-08-17 20:18:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name: Set up Docker Buildx
							 
						 
					
						
							
								
									
										
										
										
											2020-09-08 22:32:40 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        uses: docker/setup-buildx-action@v1
							 
						 
					
						
							
								
									
										
										
										
											2020-08-17 20:18:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name: Login to DockerHub
							 
						 
					
						
							
								
									
										
										
										
											2020-08-27 13:08:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        uses: docker/login-action@v1 
							 
						 
					
						
							
								
									
										
										
										
											2020-08-17 20:18:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        with:
							 
						 
					
						
							
								
									
										
										
										
											2020-09-10 16:46:50 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          username: ${{ secrets.DOCKERHUB_USERNAME }}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          password: ${{ secrets.DOCKERHUB_TOKEN }}
							 
						 
					
						
							
								
									
										
										
										
											2020-08-17 20:18:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name: Build and push
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        id: docker_build
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        uses: docker/build-push-action@v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          push: true
							 
						 
					
						
							
								
									
										
										
										
											2020-08-18 20:54:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          tags: user/app:latest
							 
						 
					
						
							
								
									
										
										
										
											2020-08-17 20:18:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name: Image digest
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        run: echo ${{ steps.docker_build.outputs.digest }}
							 
						 
					
						
							
								
									
										
										
										
											2020-09-22 18:49:18 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2020-08-17 20:18:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Building from the current repository automatically uses the [GitHub Token ](https://help.github.com/en/actions/configuring-and-managing-workflows/authenticating-with-the-github_token )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								so it does not need to be passed. If you want to authenticate against another private repository, you have to use
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								a [secret ](docs/advanced/secrets.md ) named `GIT_AUTH_TOKEN`  to be able to authenticate against it with buildx:
							 
						 
					
						
							
								
									
										
										
										
											2020-09-02 08:07:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name: Build and push
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        id: docker_build
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        uses: docker/build-push-action@v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          push: true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          tags: user/app:latest
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          secrets: |
							 
						 
					
						
							
								
									
										
										
										
											2020-09-22 18:49:18 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            GIT_AUTH_TOKEN=${{ secrets.MYTOKEN }}
							 
						 
					
						
							
								
									
										
										
										
											2020-09-02 08:07:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-11-30 12:29:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  :warning: Subdir for Git context is not yet supported ([moby/buildkit#1684](https://github.com/moby/buildkit/issues/1684))
  
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  but you can use the [path context](#path-context) in the meantime. More info on [Docker docs website](https://docs.docker.com/engine/reference/commandline/build/#git-repositories).
  
						 
					
						
							
								
									
										
										
										
											2020-10-03 21:03:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-09-02 08:07:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Path context
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-09-22 18:49:18 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								name: ci
							 
						 
					
						
							
								
									
										
										
										
											2020-09-21 16:22:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-09-22 18:49:18 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								on:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  push:
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    branches:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  'master'
							 
						 
					
						
							
								
									
										
										
										
											2020-09-21 16:22:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-09-22 18:49:18 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								jobs:
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  docker:
							 
						 
					
						
							
								
									
										
										
										
											2020-09-22 18:49:18 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    runs-on: ubuntu-latest
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    steps:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name: Checkout
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        uses: actions/checkout@v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name: Set up QEMU
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        uses: docker/setup-qemu-action@v1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name: Set up Docker Buildx
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        uses: docker/setup-buildx-action@v1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name: Login to DockerHub
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        uses: docker/login-action@v1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          username: ${{ secrets.DOCKERHUB_USERNAME }}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          password: ${{ secrets.DOCKERHUB_TOKEN }}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name: Build and push
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        uses: docker/build-push-action@v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          context: .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          push: true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          tags: user/app:latest
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2020-09-02 08:07:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-09-12 18:40:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Advanced usage
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-02-17 17:53:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  [Multi-platform image ](docs/advanced/multi-platform.md ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  [Secrets ](docs/advanced/secrets.md ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  [Isolated builders ](docs/advanced/isolated-builders.md ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  [Push to multi-registries ](docs/advanced/push-multi-registries.md ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  [Cache ](docs/advanced/cache.md ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [Registry cache ](docs/advanced/cache.md#registry-cache )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  [GitHub cache ](docs/advanced/cache.md#github-cache )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  [Local registry ](docs/advanced/local-registry.md ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  [Export image to Docker ](docs/advanced/export-docker.md ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  [Handle tags and labels ](docs/advanced/tags-labels.md ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  [Update DockerHub repo description ](docs/advanced/dockerhub-desc.md ) 
						 
					
						
							
								
									
										
										
										
											2020-09-09 23:14:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Customizing
  
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### inputs
  
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Following inputs can be used as `step.with`  keys
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-10-22 19:50:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  `List` type is a newline-delimited string
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  ```yaml
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  cache-from: |
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>    user/app:cache
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>    type=local,src=path/to/dir
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  ```
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  `CSV` type is a comma-delimited string
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  ```yaml
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  tags: name/app:latest,name/app:1.0.0
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  ```
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-10-20 17:04:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								| Name                | Type     | Description                        |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								|---------------------|----------|------------------------------------|
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `builder`            | String   | Builder instance (see [setup-buildx ](https://github.com/docker/setup-buildx-action ) action) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `context`            | String   | Build's context is the set of files located in the specified [`PATH` or `URL` ](https://docs.docker.com/engine/reference/commandline/build/ ) (default [Git context ](#git-context )) |
							 
						 
					
						
							
								
									
										
										
										
											2020-12-18 15:05:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								| `file`               | String   | Path to the Dockerfile. (default `{context}/Dockerfile` ) |
							 
						 
					
						
							
								
									
										
										
										
											2020-10-20 17:04:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								| `build-args`         | List     | List of build-time variables |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `labels`             | List     | List of metadata for an image |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `tags`               | List/CSV | List of tags |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `pull`               | Bool     | Always attempt to pull a newer version of the image (default `false` ) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `target`             | String   | Sets the target stage to build |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `allow`              | List/CSV | List of [extra privileged entitlement ](https://github.com/docker/buildx#--allowentitlement ) (eg. `network.host,security.insecure` ) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `no-cache`           | Bool     | Do not use cache when building the image (default `false` ) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `platforms`          | List/CSV | List of [target platforms ](https://github.com/docker/buildx#---platformvaluevalue ) for build |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `load`               | Bool     | [Load ](https://github.com/docker/buildx#--load ) is a shorthand for `--output=type=docker`  (default `false` ) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `push`               | Bool     | [Push ](https://github.com/docker/buildx#--push ) is a shorthand for `--output=type=registry`  (default `false` ) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `outputs`            | List     | List of [output destinations ](https://github.com/docker/buildx#-o---outputpath-typetypekeyvalue ) (format: `type=local,dest=path` ) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `cache-from`         | List     | List of [external cache sources ](https://github.com/docker/buildx#--cache-fromnametypetypekeyvalue ) (eg. `type=local,src=path/to/dir` ) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `cache-to`           | List     | List of [cache export destinations ](https://github.com/docker/buildx#--cache-tonametypetypekeyvalue ) (eg. `type=local,dest=path/to/dir` ) |
							 
						 
					
						
							
								
									
										
										
										
											2021-02-15 09:08:19 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								| `secrets`            | List     | List of secrets to expose to the build (eg. `key=string` , `GIT_AUTH_TOKEN=mytoken` ) |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `secret-files`       | List     | List of secret files to expose to the build (eg. `key=filename` , `MY_SECRET=./secret.txt` ) |
							 
						 
					
						
							
								
									
										
										
										
											2020-10-28 18:40:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								| `ssh`                | List     | List of SSH agent socket or keys to expose to the build |
							 
						 
					
						
							
								
									
										
										
										
											2020-10-20 17:04:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### outputs
  
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Following outputs are available
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								| Name          | Type    | Description                           |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								|---------------|---------|---------------------------------------|
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| `digest`       | String  | Image content-addressable identifier also called a digest |
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-09-21 16:22:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Troubleshooting
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-09-21 19:06:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								See [TROUBLESHOOTING.md ](TROUBLESHOOTING.md )
							 
						 
					
						
							
								
									
										
										
										
											2020-09-21 16:22:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-20 15:25:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Keep up-to-date with GitHub Dependabot
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Since [Dependabot ](https://docs.github.com/en/github/administering-a-repository/keeping-your-actions-up-to-date-with-github-dependabot )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								has [native GitHub Actions support ](https://docs.github.com/en/github/administering-a-repository/configuration-options-for-dependency-updates#package-ecosystem ),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								to enable it on your GitHub repo all you need to do is add the `.github/dependabot.yml`  file:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								version: 2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								updates:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  # Maintain dependencies for GitHub Actions
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  package-ecosystem: "github-actions"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    directory: "/"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    schedule:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      interval: "daily"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Limitation
  
						 
					
						
							
								
									
										
										
										
											2020-03-05 16:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-08-15 22:36:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								This action is only available for Linux [virtual environments ](https://help.github.com/en/articles/virtual-environments-for-github-actions#supported-virtual-environments-and-hardware-resources ).