9d497291e1
Co-authored-by: multica-agent <github@multica.ai>
2.1 KiB
2.1 KiB
Work Log - 修复 Buildx 安装阶段访问 Docker Hub 超时(2026-06-09)
-
背景:
- GitHub Actions run
27150975287在build-and-pushjob 的安装 Buildx步骤失败,后续镜像构建与部署全部被跳过。 - check-run annotation 给出的精确错误为:
Head "https://registry-1.docker.io/v2/moby/buildkit/manifests/buildx-stable-1" ... Client.Timeout exceeded while awaiting headers
- 根因不是仓库镜像构建脚本本身,而是
docker/setup-buildx-action默认docker-container驱动在启动 BuildKit builder 时,需要先从 Docker Hub 拉moby/buildkit:buildx-stable-1,受外网访问抖动影响直接超时。
- GitHub Actions run
-
本次处理:
.github/workflows/main.ymlactions/checkout升级到v6。docker/setup-buildx-action升级到v4,并显式指定:driver-opts: image=docker.m.daocloud.io/moby/buildkit:buildx-stable-1- 避免 Buildx 初始化再访问 Docker Hub 拉默认 BuildKit 镜像。
docker/login-action升级到v4。docker/build-push-action升级到v7。
- 兼带收益:
- 消除了该次 run 中出现的
Node.js 20 actions are deprecated预警里的旧版checkout/setup-buildx。
- 消除了该次 run 中出现的
-
验证:
- 基线:
- GitHub Actions run
27150975287失败,且失败点固定在安装 Buildx。 - check-run annotation 可复核到 Docker Hub
moby/buildkit拉取超时。
- GitHub Actions run
- 修改后:
python3解析.github/workflows/main.yml通过。actionlint校验变更前/变更后 workflow 均可解析,变更未引入 YAML / Actions 语法问题。git diff --check -- .github/workflows/main.yml通过。
- 当前环境限制:
- 无法直接在本地实际执行 GitHub hosted runner 上的
setup-buildx拉起流程,真实恢复效果需要依赖下一次 Actions 运行确认。
- 无法直接在本地实际执行 GitHub hosted runner 上的
- 基线:
-
风险与关注点:
- 本次修复只绕开 BuildKit builder 镜像对 Docker Hub 的依赖;后续若
Dockerfile里的基础镜像或docker build --pull仍指向不稳定上游,构建阶段仍可能出现其他网络相关失败。
- 本次修复只绕开 BuildKit builder 镜像对 Docker Hub 的依赖;后续若