使用 GitHub Actions 添加镜像注解
目录
注解允许您为 OCI 镜像组件指定任意元数据,例如 manifests、indexes 和 descriptors。
使用 GitHub Actions 构建镜像时,可以使用 metadata-action 自动创建符合 OCI 标准的注解。metadata action 会创建一个 annotations
输出,您可以将其与 build-push-action 和 bake-action 一起引用。
name: ci
on:
push:
env:
IMAGE_NAME: user/app
jobs:
docker:
runs-on: ubuntu-latest
steps:
- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ vars.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Extract metadata
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.IMAGE_NAME }}
- name: Build and push
uses: docker/build-push-action@v6
with:
tags: ${{ steps.meta.outputs.tags }}
annotations: ${{ steps.meta.outputs.annotations }}
push: true
name: ci
on:
push:
env:
IMAGE_NAME: user/app
jobs:
docker:
runs-on: ubuntu-latest
steps:
- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ vars.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Extract metadata
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.IMAGE_NAME }}
- name: Build
uses: docker/bake-action@v6
with:
files: |
./docker-bake.hcl
cwd://${{ steps.meta.outputs.bake-file-tags }}
cwd://${{ steps.meta.outputs.bake-file-annotations }}
push: true
配置注解级别
默认情况下,注解会放置在镜像 manifests 上。要配置注解级别,请在 metadata-action
步骤中将 DOCKER_METADATA_ANNOTATIONS_LEVELS
环境变量设置为您希望添加注解的所有级别的逗号分隔列表。例如,将 DOCKER_METADATA_ANNOTATIONS_LEVELS
设置为 index
会将注解放置在镜像 index 上,而不是 manifests 上。
以下示例在镜像 index 和 manifests 上都创建了注解。
name: ci
on:
push:
env:
IMAGE_NAME: user/app
jobs:
docker:
runs-on: ubuntu-latest
steps:
- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ vars.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Extract metadata
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.IMAGE_NAME }}
env:
DOCKER_METADATA_ANNOTATIONS_LEVELS: manifest,index
- name: Build and push
uses: docker/build-push-action@v6
with:
tags: ${{ steps.meta.outputs.tags }}
annotations: ${{ steps.meta.outputs.annotations }}
push: true
注意
构建必须产生您想要添加注解的组件。例如,要为镜像 index 添加注解,构建必须产生一个 index。如果构建只产生一个 manifest,而您指定了
index
或index-descriptor
,则构建将失败。