# GitHub Actions cache storage > **Warning** > > The GitHub Actions cache is a beta feature. You can use it today, in current > releases of Buildx and BuildKit. However, the interface and behavior are > unstable and may change in future releases. The GitHub Actions cache utilizes the [GitHub-provided Action's cache](https://github.com/actions/cache) available from within your CI execution environment. This is the recommended cache to use inside your GitHub action pipelines, as long as your use case falls within the [size and usage limits set by GitHub](https://docs.github.com/en/actions/using-workflows/caching-dependencies-to-speed-up-workflows#usage-limits-and-eviction-policy). > **Note** > > This cache storage backend requires using a different driver than the default > `docker` driver - see more information on selecting a driver > [here](https://docs.docker.com/build/building/drivers/). To create a new > driver (which can act as a simple drop-in replacement): > > ```console > $ docker buildx create --use --driver=docker-container > ``` ## Synopsis ```console $ docker buildx build --push -t / \ --cache-to type=gha[,parameters...] \ --cache-from type=gha[,parameters...] . ``` The following table describes the available CSV parameters that you can pass to `--cache-to` and `--cache-from`. | Name | Option | Type | Default | Description | | ------- | ----------------------- | ----------- | ------------------------------- | -------------------------------------------- | | `url` | `cache-to`,`cache-from` | String | `$ACTIONS_CACHE_URL` | Cache server URL, see [authentication][1]. | | `token` | `cache-to`,`cache-from` | String | `$ACTIONS_RUNTIME_TOKEN` | Access token, see [authentication][1]. | | `scope` | `cache-to`,`cache-from` | String | Name of the current Git branch. | Cache scope, see [scope][2] | | `mode` | `cache-to` | `min`,`max` | `min` | Cache layers to export, see [cache mode][3]. | [1]: #authentication [2]: #scope [3]: index.md#cache-mode ## Authentication If the `url` or `token` parameters are left unspecified, the `gha` cache backend will fall back to using environment variables. If you invoke the `docker buildx` command manually from an inline step, then the variables must be manually exposed (using [`crazy-max/ghaction-github-runtime`](https://github.com/crazy-max/ghaction-github-runtime), for example). ## Scope By default, cache is scoped per Git branch. This ensures a separate cache environment for the main branch and each feature branch. If you build multiple images on the same branch, each build will overwrite the cache of the previous, leaving only the final cache. To preserve the cache for multiple builds on the same branch, you can manually specify a cache scope name using the `scope` parameter. In the following example, the cache is set to a combination of the branch name and the image name, to ensure each image gets its own cache): ```console $ docker buildx build --push -t / \ --cache-to type=gha,url=...,token=...,scope=$GITHUB_REF_NAME-image \ --cache-from type=gha,url=...,token=...,scope=$GITHUB_REF_NAME-image . $ docker buildx build --push -t / \ --cache-to type=gha,url=...,token=...,scope=$GITHUB_REF_NAME-image2 \ --cache-from type=gha,url=...,token=...,scope=$GITHUB_REF_NAME-image2 . ``` GitHub's [cache access restrictions](https://docs.github.com/en/actions/advanced-guides/caching-dependencies-to-speed-up-workflows#restrictions-for-accessing-a-cache), still apply. Only the cache for the current branch, the base branch and the default branch is accessible by a workflow. ### Using `docker/build-push-action` When using the [`docker/build-push-action`](https://github.com/docker/build-push-action), the `url` and `token` parameters are automatically populated. No need to manually specify them, or include any additional workarounds. For example: ```yaml - name: Build and push uses: docker/build-push-action@v3 with: context: . push: true tags: "/:latest" cache-from: type=gha cache-to: type=gha,mode=max ``` ## Further reading For an introduction to caching see [Optimizing builds with cache](https://docs.docker.com/build/building/cache). For more information on the `gha` cache backend, see the [BuildKit README](https://github.com/moby/buildkit#github-actions-cache-experimental).