diff --git a/.github/workflows/github-image.yml b/.github/workflows/github-image.yml index 05dcffc..f670fad 100644 --- a/.github/workflows/github-image.yml +++ b/.github/workflows/github-image.yml @@ -1,60 +1,65 @@ -# This workflow uses actions that are not certified by GitHub. -# They are provided by a third-party and are governed by -# separate terms of service, privacy policy, and support -# documentation. - -# GitHub recommends pinning actions to a commit SHA. -# To get a newer version, you will need to update the SHA. -# You can also reference a tag or branch, but the action may change without warning. - -# Create a Docker image and push it to ghcr.io whenever a new version tag is pushed - -name: GHCR Image CI +# 工作流名称 +name: Build Docker Image +# push tag 时触发执行 on: push: tags: - - "v*.*.*" + - v* +# 定义环境变量, 后面会使用 +# 定义 APP_NAME 用于 docker build-args +# 定义 DOCKERHUB_REPO 标记 docker hub repo 名称 env: - REGISTRY: ghcr.io - IMAGE_NAME: ${{ github.repository }} + APP_NAME: pairdrop + DOCKERHUB_REPO: sage417/pairdrop jobs: - build-and-push-image: + main: + # 在 Ubuntu 上运行 runs-on: ubuntu-latest - permissions: - contents: read - packages: write - steps: - - name: Checkout repository - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 - - - name: Setup qemu - uses: docker/setup-qemu-action@68827325e0b33c7199eb31dd4e31fbe9023e06e3 # v3.0.0 - - - name: Setup Docker Buildx - uses: docker/setup-buildx-action@f95db51fddba0c2d1ec667646a06c2ce06100226 # v3.0.0 - - - name: Log in to the Container registry - uses: docker/login-action@343f7c4344506bcbf9b4de18042ae17996df046d # v3.0.0 + # git checkout 代码 + - name: Checkout + uses: actions/checkout@v4 + # 设置 QEMU, 后面 docker buildx 依赖此. + - name: Set up QEMU + uses: docker/setup-qemu-action@v3 + # 设置 Docker buildx, 方便构建 Multi platform 镜像 + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + # 登录 docker hub + - name: Login to DockerHub + uses: docker/login-action@v1 with: - registry: ${{ env.REGISTRY }} - username: ${{ github.actor }} - password: ${{ secrets.GITHUB_TOKEN }} - + # GitHub Repo => Settings => Secrets 增加 docker hub 登录密钥信息 + # DOCKERHUB_USERNAME 是 docker hub 账号名. + # DOCKERHUB_TOKEN: docker hub => Account Setting => Security 创建. + username: ${{ secrets.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_TOKEN }} - name: Extract metadata (tags, labels) for Docker id: meta uses: docker/metadata-action@31cebacef4805868f9ce9a0cb03ee36c32df2ac4 # v5.3.0 with: - images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} - - - name: Build and push Docker image - uses: docker/build-push-action@4a13e500e55cf31b7a5d59a38ab2040ab0f42f56 # v5.1.0 + images: ${{ env.DOCKERHUB_REPO }}/${{ env.APP_NAME }} + # 构建 Docker 并推送到 Docker hub + - name: Build and push + id: docker_build + uses: docker/build-push-action@v5 with: - context: . - platforms: linux/amd64,linux/arm64 + # 是否 docker push push: true - tags: ${{ steps.meta.outputs.tags }} + # 生成多平台镜像, see https://github.com/docker-library/bashbrew/blob/v0.1.1/architecture/oci-platform.go + platforms: | + linux/arm/v6 + linux/arm/v7 + linux/arm64/v8 + # docker build arg, 注入 APP_NAME/APP_VERSION + build-args: | + APP_NAME=${{ env.APP_NAME }} + APP_VERSION=${{ env.APP_VERSION }} + # 生成两个 docker tag: ${APP_VERSION} 和 latest + tags: | + ${{ env.DOCKERHUB_REPO }}:latest + ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }}