GitLab CI 与 Jenkins

GitLab 代码提交 → Jenkins 人工确认环境 → 部署 → 触发对应环境接口自动化测试 ,jenkins在这个流程中的作用

一、定位 Jenkins

GitLab CI 只管 "代码提交自动构建打包"; Jenkins 负责 "人工确认发布环境 + 触发部署 + 触发对应环境自动化测试",是 CD 阶段的发布调度与审批中枢 。

二、完整全流程

plaintext

复制代码
1. 本地 git push → GitLab
2. GitLab CI 自动:构建 → 单元测试 → 打包 Docker 镜像 → 推镜像仓库
3. 镜像构建完成 → 通知 Jenkins
4. 人工在 Jenkins 选择:发布到 开发/测试/预发/生产 环境(确认环境)
5. Jenkins 执行:调用 K8s / 脚本部署到对应环境
6. 部署完成 → Jenkins 自动触发对应环境的接口自动化测试
7. 测试通过 → 流程结束;失败则阻断上线

三、Jenkins 在流程里的 4 个核心作用

1. 环境发布审批入口

GitLab CI 全自动、无人工; 但生产环境不能自动发 ,必须人工确认。 Jenkins 提供:手动选择环境、人工点击发布,做权限管控、发布确认。

2. 统一部署调度

Jenkins 根据你选的环境:

  • 选开发 → 部署到 dev 命名空间
  • 选测试 → 部署到 test 命名空间
  • 选生产 → 部署到 prod 命名空间 统一调用 K8s / Docker 部署,不用写一堆脚本。

3. 部署后自动触发对应环境接口自动化

特点:

部署到哪个环境,就跑哪个环境的接口自动化 由 Jenkins 调度执行自动化测试脚本(JMeter/Pytest)。

4. 发布记录、日志、回滚

所有发布记录、测试报告、失败日志全部存在 Jenkins,方便追溯、回滚。

四、和 GitLab CI 分工

  • GitLab CI(CI 阶段) :只管代码层面 构建、单元测试、打包镜像,全自动,代码一提交就跑
  • Jenkins(CD 阶段) :只管发布与环境 人工确认环境 → 部署 → 环境级接口自动化测试

五、Docker / Nginx / K8s / Jenkins 整体关系

  • Docker:打包应用镜像
  • GitLab CI:自动打包镜像
  • Jenkins:人工选环境 → 指挥 K8s 部署
  • K8s:在对应环境启动容器
  • Nginx (Ingress):流量入口
  • Jenkins 再触发:该环境的接口自动化测试

六、总结

我们公司采用 GitLab CI + Jenkins 双流水线模式。 GitLab CI 负责代码提交后自动构建、单元测试、打包 Docker 镜像; Jenkins 作为发布中枢,提供人工确认发布环境的能力,选择对应环境后自动通过 K8s 部署,部署完成后触发对应环境的接口自动化测试,实现环境级质量校验。

相关推荐
sbjdhjd10 小时前
从零搭建企业级 CI/CD(下):Jenkins+GitLab+Harbor 全链路实战指南
git·servlet·ci/cd·云原生·云计算·gitlab·jenkins
糖果店的幽灵13 小时前
软件测试接口测试从入门到精通:接口测试CI_CD集成
软件测试·ci/cd·接口测试
changxiang1 天前
Jenkins备忘
运维·jenkins
用什么都重名1 天前
Git 合并两个无共同历史的分支:从报错到解决全记录
git·gitlab
master3361 天前
GitLab (Docker) 常用命令及解决方案清单
docker·容器·gitlab
qq_356408661 天前
GitLab 单机私有化部署文档(基于 Docker 环境)
docker·gitlab
平头老王1 天前
CI/CD流水线设计 — 第1章:常见误区
ci/cd·自动化·devops·持续部署·持续集成
星落zx2 天前
在CI/CD流水线里接入多模型自动Code Review,踩坑与方案分享
人工智能·ci/cd·代码复审
又是进步的一天2 天前
一台虚拟机学习CI流程
学习·ci/cd·云原生·容器·kubernetes·devops
未若君雅裁3 天前
日志采集与ELK:从本地日志到集中检索分析
运维·elk·jenkins