mirror of
https://github.com/yeasy/docker_practice.git
synced 2026-03-11 12:21:17 +00:00
1.3 KiB
1.3 KiB
21.2 GitHub Actions
GitHub Actions 是 GitHub 推出的一款 CI/CD 工具。
我们可以在每个 job 的 step 中使用 Docker 执行构建步骤。
21.2.1 最小可用示例
在仓库根目录创建 /.github/workflows/ci.yml:
name: CI
on:
push:
pull_request:
permissions:
contents: read
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: docker/setup-buildx-action@v3
- uses: docker/build-push-action@v6
with:
context: .
push: false
tags: local/test:ci
该示例会在 GitHub Actions 中构建当前仓库的 Docker 镜像(不推送到 registry)。
21.2.2 最佳实践
- 固定 action 的主版本(例如
@v4/@v6),避免使用@master这类浮动引用。 - 设置最小权限(例如
contents: read),需要写入权限时再打开。 - 需要依赖缓存时,优先使用官方支持的缓存方案(例如针对语言包管理器的 cache 或 BuildKit cache)。
如果你需要在某个步骤里直接运行容器镜像(而不是构建镜像),可以使用 docker:// 语法:
- name: Run container step
uses: docker://golang:alpine
with:
args: go version