180 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			180 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| [](https://github.com/docker/setup-buildx-action/releases/latest)
 | |
| [](https://github.com/marketplace/actions/docker-setup-buildx)
 | |
| [](https://github.com/docker/setup-buildx-action/actions?workflow=ci)
 | |
| [](https://github.com/docker/setup-buildx-action/actions?workflow=test)
 | |
| [](https://codecov.io/gh/docker/setup-buildx-action)
 | |
| 
 | |
| ## About
 | |
| 
 | |
| GitHub Action to set up Docker [Buildx](https://github.com/docker/buildx).
 | |
| 
 | |
| This action will create and boot a builder that can be used in the following
 | |
| steps of your workflow if you're using Buildx or the [`build-push` action](https://github.com/docker/build-push-action/).
 | |
| By default, the [`docker-container` driver](https://docs.docker.com/build/building/drivers/docker-container/)
 | |
| will be used to be able to build multi-platform images and export cache using
 | |
| a [BuildKit](https://github.com/moby/buildkit) container.
 | |
| 
 | |
| 
 | |
| 
 | |
| ___
 | |
| 
 | |
| * [Usage](#usage)
 | |
| * [Advanced usage](#advanced-usage)
 | |
|   * [Authentication support](docs/advanced/auth.md)
 | |
|   * [Install by default](docs/advanced/install-default.md)
 | |
|   * [BuildKit daemon configuration](docs/advanced/buildkit-config.md)
 | |
|   * [Standalone mode](docs/advanced/standalone.md)
 | |
| * [Customizing](#customizing)
 | |
|   * [inputs](#inputs)
 | |
|   * [outputs](#outputs)
 | |
|   * [environment variables](#environment-variables)
 | |
| * [Notes](#notes)
 | |
|   * [`nodes` output](#nodes-output)
 | |
|   * [BuildKit container logs](#buildkit-container-logs)
 | |
| * [Keep up-to-date with GitHub Dependabot](#keep-up-to-date-with-github-dependabot)
 | |
| 
 | |
| ## Usage
 | |
| 
 | |
| ```yaml
 | |
| name: ci
 | |
| 
 | |
| on:
 | |
|   push:
 | |
| 
 | |
| jobs:
 | |
|   buildx:
 | |
|     runs-on: ubuntu-latest
 | |
|     steps:
 | |
|       -
 | |
|         name: Checkout
 | |
|         uses: actions/checkout@v3
 | |
|       -
 | |
|         # Add support for more platforms with QEMU (optional)
 | |
|         # https://github.com/docker/setup-qemu-action
 | |
|         name: Set up QEMU
 | |
|         uses: docker/setup-qemu-action@v2
 | |
|       -
 | |
|         name: Set up Docker Buildx
 | |
|         uses: docker/setup-buildx-action@v2
 | |
| ```
 | |
| 
 | |
| ## Advanced usage
 | |
| 
 | |
| * [Authentication support](docs/advanced/auth.md)
 | |
| * [Install by default](docs/advanced/install-default.md)
 | |
| * [BuildKit daemon configuration](docs/advanced/buildkit-config.md)
 | |
| * [Standalone mode](docs/advanced/standalone.md)
 | |
| 
 | |
| ## Customizing
 | |
| 
 | |
| ### inputs
 | |
| 
 | |
| Following inputs can be used as `step.with` keys
 | |
| 
 | |
| | Name              | Type   | Description                                                                                                                                                                                     |
 | |
| |-------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
 | |
| | `version`         | String | [Buildx](https://github.com/docker/buildx) version. (eg. `v0.3.0`, `latest`, `https://github.com/docker/buildx.git#master`)                                                                     |
 | |
| | `driver`          | String | Sets the [builder driver](https://docs.docker.com/engine/reference/commandline/buildx_create/#driver) to be used (default `docker-container`)                                                   |
 | |
| | `driver-opts`     | CSV    | List of additional [driver-specific options](https://docs.docker.com/engine/reference/commandline/buildx_create/#driver-opt) (eg. `image=moby/buildkit:master`)                                 |
 | |
| | `buildkitd-flags` | String | [Flags for buildkitd](https://docs.docker.com/engine/reference/commandline/buildx_create/#buildkitd-flags) daemon (since [buildx v0.3.0](https://github.com/docker/buildx/releases/tag/v0.3.0)) |
 | |
| | `install`         | Bool   | Sets up `docker build` command as an alias to `docker buildx` (default `false`)                                                                                                                 |
 | |
| | `use`             | Bool   | Switch to this builder instance (default `true`)                                                                                                                                                |
 | |
| | `endpoint`        | String | [Optional address for docker socket](https://docs.docker.com/engine/reference/commandline/buildx_create/#description) or context from `docker context ls`                                       |
 | |
| | `config`¹         | String | [BuildKit config file](https://docs.docker.com/engine/reference/commandline/buildx_create/#config)                                                                                              |
 | |
| | `config-inline`¹  | String | Same as `config` but inline                                                                                                                                                                     |
 | |
| 
 | |
| > * ¹ `config` and `config-inline` are mutually exclusive
 | |
| 
 | |
| > `CSV` type must be a newline-delimited string
 | |
| > ```yaml
 | |
| > driver-opts: image=moby/buildkit:master
 | |
| > ```
 | |
| > ```yaml
 | |
| > driver-opts: |
 | |
| >   image=moby/buildkit:master
 | |
| >   network=host
 | |
| > ```
 | |
| 
 | |
| ### outputs
 | |
| 
 | |
| Following outputs are available
 | |
| 
 | |
| | Name        | Type   | Description                                     |
 | |
| |-------------|--------|-------------------------------------------------|
 | |
| | `name`      | String | Builder name                                    |
 | |
| | `driver`    | String | Builder driver                                  |
 | |
| | `platforms` | String | Builder node platforms (preferred or available) |
 | |
| | `nodes`     | JSON   | Builder [nodes metadata](#nodes-output)         |
 | |
| 
 | |
| ### environment variables
 | |
| 
 | |
| The following [official docker environment variables](https://docs.docker.com/engine/reference/commandline/cli/#environment-variables) are supported:
 | |
| 
 | |
| | Name            | Type   | Default     | Description                                     |
 | |
| |-----------------|--------|-------------|-------------------------------------------------|
 | |
| | `DOCKER_CONFIG` | String | `~/.docker` | The location of your client configuration files |
 | |
| 
 | |
| ## Notes
 | |
| 
 | |
| ### `nodes` output
 | |
| 
 | |
| ```json
 | |
| [
 | |
|   {
 | |
|      "name": "builder-3820d274-502c-4498-ae24-d4c32b3023d90",
 | |
|      "endpoint": "unix:///var/run/docker.sock",
 | |
|      "driver-opts": [
 | |
|        "network=host",
 | |
|        "image=moby/buildkit:master"
 | |
|      ],
 | |
|     "status": "running",
 | |
|     "buildkitd-flags": "--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host",
 | |
|     "buildkit": "3fab389",
 | |
|     "platforms": "linux/amd64,linux/amd64/v2,linux/amd64/v3,linux/amd64/v4,linux/386"
 | |
|   }
 | |
| ]
 | |
| ```
 | |
| 
 | |
| | Name              | Type   | Description                |
 | |
| |-------------------|--------|----------------------------|
 | |
| | `name`            | String | Node name                  |
 | |
| | `endpoint`        | String | Node endpoint              |
 | |
| | `driver-opts`     | List   | Options for the driver     |
 | |
| | `status`          | String | Node status                |
 | |
| | `buildkitd-flags` | String | Flags for buildkitd daemon |
 | |
| | `buildkit`        | String | BuildKit version           |
 | |
| | `platforms`       | String | Platforms available        |
 | |
| 
 | |
| ### BuildKit container logs
 | |
| 
 | |
| To display BuildKit container logs (when `docker-container` driver is used) you have to [enable step debug logging](https://docs.github.com/en/actions/managing-workflow-runs/enabling-debug-logging#enabling-step-debug-logging),
 | |
| or you can also enable debugging in the [setup-buildx action step](https://github.com/docker/setup-buildx-action):
 | |
| 
 | |
| ```yaml
 | |
|   -
 | |
|     name: Set up Docker Buildx
 | |
|     uses: docker/setup-buildx-action@v2
 | |
|     with:
 | |
|       buildkitd-flags: --debug
 | |
| ```
 | |
| 
 | |
| Logs will be available at the end of a job:
 | |
| 
 | |
| 
 | |
| 
 | |
| ## 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"
 | |
| ```
 | 
