返回顶部
G

GitLabGitLab避坑指南

Avoid common GitLab CI/CD mistakes — rules gotchas, silent failures, and YAML merge traps.

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 1.0.0
安全检测
已通过
1,877
下载量
免费
免费
5
收藏
概述
安装方式
版本历史

GitLab

规则陷阱

  • - rules: 和 only:/except: 不能混用——每个作业只能选择其中一种
  • 首个匹配的规则优先——将具体规则放在通用规则之前
  • 缺少 when: 时默认值为 onsuccess——rules: - if: $CICOMMIT_TAG 会在标签上运行
  • 空规则数组 rules: [] 表示永不运行——这与完全没有规则不同
  • 在末尾添加 - when: never 以防止穿透——否则未匹配的条件可能会运行

静默失败

  • - 非保护分支上缺少保护变量——作业会运行但变量为空
  • Runner 标签不匹配——作业会无限期等待且不报错
  • 在非特权 Runner 上使用 docker:dind——会因模糊的 Docker 错误而失败
  • 掩码变量格式无效——变量仍会在日志中暴露

YAML 合并陷阱

  • - extends: 不会深度合并数组——scripts、variables 数组会被替换而非追加
  • 使用 !reference [.job, script] 来复用——script: [!reference [.base, script], my command]
  • include: 文件可以互相覆盖——相同键名时最后一个生效
  • 锚点 &/* 不能跨文件使用——跨文件复用请使用 extends:

产物与缓存

  • - 缓存不保证在运行间可用——将其视为优化而非必要条件
  • 产物按阶段自动下载——添加 dependencies: [] 可在不需要时跳过
  • needs: 默认会下载产物——使用 needs: [{job: x, artifacts: false}] 可跳过

Docker-in-Docker

  • - 共享 Runner 通常不支持特权模式——需要自托管或特殊配置
  • 需要设置 DOCKERHOST: tcp://docker:2375——否则作业会使用错误的 Docker
  • 设置 DOCKERTLS_CERTDIR: 或正确配置 TLS——半配置的 TLS 会破坏构建

流水线触发

  • - CIPIPELINESOURCE 因触发方式而异——push、mergerequestevent、schedule、api、trigger
  • MR 流水线需要 rules: - if: $CIMERGEREQUEST_IID——不仅仅是分支规则
  • 分离流水线与合并结果流水线——分离流水线测试源分支,合并结果流水线测试合并结果

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 gitlab-1776203437 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 gitlab-1776203437 技能

通过命令行安装

skillhub install gitlab-1776203437

下载

⬇ 下载 GitLab v1.0.0(免费)

文件大小: 1.74 KB | 发布时间: 2026-4-15 10:54

v1.0.0 最新 2026-4-15 10:54
Initial release

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部