项目:Gitlab HSD CI/CD总结

核心成分:

  • gitlab-ci.yaml 定义部署的 jobs(操控 runner)
  • gitlab runner 负责运行 jobs(注册 / 启动容器)
  • pipeline:执行 gitlab-ci,将 jobs 分配给 runner(不用管)
  • vault 存储环境变量(lets 拉取)

gitlab-runner:

不算特别了解

存在多种形式,可以是 docker 容器、k8s pod 或者整个 node。

runner 本身也可以定义 executor,如 docker 或 shell。如果是 docker,可以在 gitlab-ci 定义用哪个镜像。

HSD 在部署阶段在 20E 用 docker + shell executor 注册 runner,大致流程如下:

1). 从 gitlab 设置页面注册新的 runner,指定 tag 并记录 token

2). 用 token 设置 config 文件

3). docker run 运行 runner 镜像,并用 config 文件配置

gitlab-ci:

  • 可以定义 stages 和 jobs。通常而言,按照 stages 的顺序执行,每个 stages 的所有 jobs 完成后再执行下一个。

  • jobs 需要设置的地方有 script、tag 和 image:

    script 描述每个 job 执行的脚本

    tag 指定分配给哪个 runner 执行

    image 在 executor 是 docker / k8s 容器的情况下指定镜像

  • build job:

    用了 gcr.io/kaniko-project/executor 的镜像。kaniko 专门用来编译镜像。编译完成后推送到 gitlab(在 --destination 定义推送的库)

    在推送时,设置 CI_COMMIT_SHORT_SHA 为镜像版本

  • deploy job:

    用 lets 拉取 vault 的变量,生成一长串代码 cmd,然后通过 ssh 在 20E 执行代码。

    cmd 内容:用 export 赋值环境变量后执行 docker pull

  • 环境变量:
    CI_REGISTRY:gitlab 拉取镜像的 url。虽然 registry 和 repo 中文都算库,但 registry 包含多个 repo
    CI_REGISTRY_IMAGE:默认的镜像注册 url,等于 $CI_REGISTRY/$CI_PROJECT_PATH
    CI_PROJECT_PATH:repo 的路径
    CI_PROJECT_DIR:项目根目录在放 runner 的地址,用来获取文件
    CI_COMMIT_TAGCI_COMMIT_SHACI_COMMIT_SHORT_SHA:git commit 的编号。CI_COMMIT_SHORT_SHA 是常用的8字符编码。
    CI_REGISTRY_USERCI_REGISTRY_PASSWORD:每个 job 自动生成的账户,用于推送 / 拉取 gitlab 仓库的镜像。

相关推荐
裴东青13 小时前
10-实战:RuoYi-Cloud的自动化发布
运维·ci/cd·自动化
牛奶咖啡1315 小时前
k8s容器编排技术实践——使用containerd作为容器运行时部署k8s集群
kubernetes·k8s的安装部署·开启系统的ipvs支持·安装containerd·containerd配置加速器·安装k8s的工具·安装calico网络插件
裴东青16 小时前
08-实战:RuoYi-Vue项目的自动化发布
ci/cd·自动化
2301_7807896617 小时前
手游遇到攻击为什么要用SDK游戏盾手游遇到攻击为什么要用 SDK 游戏盾?
安全·web安全·游戏·架构·kubernetes·ddos
珂玥c18 小时前
k8s集群ingress碎碎念
云原生·容器·kubernetes
佳杰云星18 小时前
如何给大模型集群选“大脑”?智算调度与管理平台 10 维选型指南(附选型评分表)
人工智能·kubernetes·大模型·云计算·gpu·算力调度·智算中心
比特森林探险记20 小时前
context 在 gRPC / Gin / K8s 中的实战
容器·kubernetes·gin
汪汪大队u21 小时前
基于 K8s 的物联网平台运维体系:Ansible+Zabbix 自动化监控与故障自愈(三)—— Zabbix Server 启动排错记
运维·kubernetes·ansible
日取其半万世不竭1 天前
OpenCost:Kubernetes 成本监控,开源的云资源费用分析
容器·kubernetes·开源
Cat_Rocky1 天前
k8s zabbix7学习-设置告警
学习·容器·kubernetes