Actions Runner Controller 中使用私有容器镜像的配置指南
问题背景
在使用 Actions Runner Controller (ARC) 的 gha-runner-scale-set 组件时,许多用户在尝试使用私有容器镜像作为 runner 模板时会遇到 ErrImagePull 错误。这种问题通常发生在将默认的公共镜像 ghcr.io/actions/actions-runner:latest 替换为私有镜像 ghcr.io/<组织名>/gha-runners:latest 时。
核心问题分析
当 Kubernetes 尝试从私有容器注册表拉取镜像时,需要提供适当的认证凭据。这个问题本质上是因为 runner pod 没有配置正确的 imagePullSecrets,导致无法从私有仓库拉取镜像。
解决方案
基础配置
正确的配置方法是在 runner 模板的 spec 部分添加 imagePullSecrets 字段:
template:
spec:
imagePullSecrets:
- name: github-pat # 这里使用你创建的 Secret 名称
containers:
- name: runner
image: ghcr.io/<my-org>/gha-runners:latest
command: ["/home/runner/run.sh"]
完整实施步骤
-
创建 Kubernetes Secret: 首先需要创建一个包含 GitHub 个人访问令牌(PAT)的 Secret:
kubectl create secret docker-registry github-pat \ --docker-server=ghcr.io \ --docker-username=<GitHub用户名> \ --docker-password=<个人访问令牌> \ --docker-email=<你的邮箱> -
验证 Secret: 确保 Secret 已正确创建并包含所需字段:
kubectl get secret github-pat -o yaml -
配置 Helm Values: 在 Helm chart 的 values 文件中添加 imagePullSecrets 配置:
imagePullSecrets: - name: github-pat -
部署验证: 部署后,检查 runner pod 是否能够正常启动并拉取镜像。
进阶问题:工作流中的容器镜像
值得注意的是,即使 runner pod 本身能够正常启动,当在工作流中使用 container.image 指定容器时,这些工作流 pod 不会自动继承 runner pod 的 imagePullSecrets 配置。这是因为:
- 工作流容器是通过容器钩子(container hooks)创建的
- 这些钩子会创建独立的 pod 规范
- 需要单独为这些工作流容器提供拉取凭据
最佳实践建议
- 统一凭证管理:考虑使用 Kubernetes 的 ServiceAccount 来集中管理镜像拉取凭据
- 最小权限原则:确保使用的 PAT 仅具有必要的权限(通常只需要 packages:read)
- 多环境支持:在不同环境(开发、测试、生产)中使用不同的凭证和镜像仓库
- 监控配置:定期检查 Secret 的有效性,特别是当使用 PAT 时,注意令牌的有效期
通过以上配置,用户可以在 Actions Runner Controller 中顺利使用私有容器镜像作为 runner,同时也能够处理工作流中使用的私有容器镜像的认证问题。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0152- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112