CrazyMax 1ae53ef326
Update README
Signed-off-by: CrazyMax <crazy-max@users.noreply.github.com>
2020-08-16 23:34:08 +02:00
2020-08-16 23:15:54 +02:00
2020-08-16 23:01:53 +02:00
2020-08-14 19:49:19 +02:00
2020-08-14 19:49:19 +02:00
2020-08-16 23:01:53 +02:00
2020-08-11 21:05:57 +02:00
2020-08-16 00:36:41 +02:00
2020-08-16 00:36:41 +02:00
2020-08-16 00:36:41 +02:00
2020-08-16 22:38:03 +02:00
2020-03-17 18:43:10 -07:00
2020-08-16 23:01:53 +02:00
2020-08-16 23:34:08 +02:00
2020-08-16 00:36:41 +02:00
2020-08-16 22:31:37 +02:00

About

GitHub Action to build and push Docker images.


Usage

This action uses our setup-buildx action that extends the docker build command named buildx with the full support of the features provided by Moby BuildKit builder toolkik. This includes multi-arch build, build-secrets, remote cache, etc. and different builder deployment/namespacing options.

Quick start

name: ci

on:
  pull_request:
    branches: master
  push:
    branches: master
    tags:

jobs:
  buildx:
    runs-on: ubuntu-latest
    steps:
      -
        name: Checkout
        uses: actions/checkout@v2
      -
        name: Set up QEMU
        uses: docker/setup-qemu-action@v1
        with:
          platforms: all
      -
        name: Set up Docker Buildx
        id: buildx
        uses: docker/setup-buildx-action@v1
      -
        name: Login to DockerHub
        uses: crazy-max/ghaction-docker-login@v1 # switch to docker/login-action@v1 when available 
        with:
          username: ${{ secrets.DOCKER_USERNAME }}
          password: ${{ secrets.DOCKER_PASSWORD }}
      -
        name: Build and push
        uses: docker/build-push-action@v2
        with:
          builder: ${{ steps.buildx.outputs.name }}
          platforms: linux/amd64,linux/arm/v6,linux/arm/v7,linux/arm64,linux/386,linux/ppc64le,linux/s390x
          push: true
          tags: |
            user/app:latest
            user/app:1.0.0

Bake

Buildx bake is also available with this action through the bake inputs:

name: ci

on:
  pull_request:
    branches: master
  push:
    branches: master
    tags:

jobs:
  bake:
    runs-on: ubuntu-latest
    steps:
      -
        name: Checkout
        uses: actions/checkout@v2
      -
        name: Set up QEMU
        uses: docker/setup-qemu-action@v1
        with:
          platforms: all
      -
        name: Set up Docker Buildx
        id: buildx
        uses: docker/setup-buildx-action@v1
      -
        name: Login to DockerHub
        uses: crazy-max/ghaction-docker-login@v1 # switch to docker/login-action@v1 when available
        with:
          username: ${{ secrets.DOCKER_USERNAME }}
          password: ${{ secrets.DOCKER_PASSWORD }}
      -
        name: Build and push
        uses: docker/build-push-action@v2
        with:
          builder: ${{ steps.buildx.outputs.name }}
          push: true
          bake: true
          bake-files: |
            ./config.hcl
          bake-targets: |
            default
            release

Git context

You can build from Git directly without actions/checkout action, even in private repositories if your context is a valid Git url:

name: ci

on:
  pull_request:
    branches: master
  push:
    branches: master
    tags:

jobs:
  git-context:
    runs-on: ubuntu-latest
    steps:
      -
        name: Set up QEMU
        uses: docker/setup-qemu-action@v1
        with:
          platforms: all
      -
        name: Set up Docker Buildx
        id: buildx
        uses: docker/setup-buildx-action@v1
        with:
          version: latest
      -
        name: Login to DockerHub
        uses: crazy-max/ghaction-docker-login@v1 # switch to docker/login-action@v1 when available
        with:
          username: ${{ secrets.DOCKER_USERNAME }}
          password: ${{ secrets.DOCKER_PASSWORD }}
      -
        name: Build and push
        uses: ./
        env:
          GIT_AUTH_TOKEN: ${{ github.token }}
          GIT_REF: ${{ github.ref }}
        with:
          context: ${{ github.repositoryUrl }}
          builder: ${{ steps.buildx.outputs.name }}
          platforms: linux/amd64,linux/arm64,linux/386
          push: true
          tags: |
            name/app:latest
            name/app:1.0.0

Customizing

inputs

Following inputs can be used as step.with keys

Name Type Default Description
builder String Builder instance (see setup-buildx action)
context String . Build's context is the set of files located in the specified PATH or URL
file String ./Dockerfile Path to the Dockerfile.
build-args List Newline-delimited list of build-time variables
labels List Newline-delimited list of metadata for an image
tags List Newline-delimited list of tags
pull Bool false Always attempt to pull a newer version of the image
target String Sets the target stage to build
allow String Allow extra privileged entitlement (eg. network.host,security.insecure)
no-cache Bool false Do not use cache when building the image
platforms String Comma-delimited list of target platforms for build
load Bool false Load is a shorthand for --output=type=docker
push Bool false Push is a shorthand for --output=type=registry
outputs List Newline-delimited list of output destinations (format: type=local,dest=path)
cache-from List Newline-delimited list of external cache sources (eg. user/app:cache, type=local,src=path/to/dir)
cache-to List Newline-delimited list of cache export destinations (eg. user/app:cache, type=local,dest=path/to/dir)
bake Bool false Use bake as the high-level build command
bake-files List Newline-delimited list of bake definition files
bake-targets List Newline-delimited list of bake targets

outputs

Following outputs are available

Name Type Description
digest String Image content-addressable identifier also called a digest

environment variables

Following environment variables can be used as step.env keys

Name Description
GIT_AUTH_HEADER¹ Raw authorization header to authenticate against git repository
GIT_AUTH_TOKEN¹ x-access-token basic auth to authenticate against git repository
GIT_REF¹ Git refrerence to use against git repository

¹ Only used if input.context is a valid git uri.

Limitation

This action is only available for Linux virtual environments.

Description
GitHub Action to build and push Docker images with Buildx
Readme Pixar 259 MiB
Languages
TypeScript 90.1%
Dockerfile 7.6%
HCL 1.9%
Go 0.4%