本篇可以了解群组级别管理下部署冻结的好处,也可以遵循下面步骤一步一步实施。
在持续集成和持续部署 (CI/CD) 的动态环境中,在假期、产品发布或维护时段等关键时期保持系统稳定性可能是具有挑战性的。在活动高峰期引入新代码会增加影响用户体验的风险。为了在创新和稳定性之间取得平衡,组织可能需要群组级别的部署冻结——在跨群组将新代码更改部署到某些分支或环境时进行战略性暂停。
鉴于极狐GitLab 可用于持续集成和持续部署工作,极狐GitLab 的 Deploy Freeze 功能旨在满足这一确切需求。
在项目过程中,部署冻结可以防止你在设置部署冻结期指定的时间段内产生新版本而造成的困扰。部署冻结有助于减少为单个项目持续部署更改时的不确定性和风险。
然而,大多数团队,不可能做到一个项目就能代表其所有生产环境。鉴于部署冻结是在项目级别设置的,在许多项目中管理和执行部署冻结可能是一项艰巨且容易出错的任务,从而导致不可预测性和中断。显然,需要一个自动化的跨项目解决方案来确保稳定性。
极狐GitLab 群组部署冻结项目将单个项目部署冻结的概念提升到了一个新的层次。它使您能够从极狐GitLab UI 上,来对极狐GitLab 群组内的一个或多个项目强制执行相同的部署限制。
无论您是管理一大套微服务还是管理一组相关项目,群组管理的部署冻结解决方案都提供了一种集中的机制来保持稳定性。
通过允许您从单个位置管理多个项目的部署冻结来遵守您的部署策略。这简化了流程并减少了人为的误操作。
在整个极狐GitLab 群组中强制部署冻结可确保所有项目同时收到相同的计划。这可以保持项目之间的一致性。
开发和运维团队的变化可见性可以有效地协调他们的工作。
借助极狐GitLab 群组部署冻结功能,极狐GitLab CI 成为用于与操作相关更改的通用自动化工具,例如在许多项目上设置部署冻结。
在以下步骤中,您将成功设置群组部署冻结功能。切记把测试做到底并确认下团队部署过程的任何具体细微差别。
要使用极狐GitLab CI 创作和自动化所有项目的批量更新部署冻结的过程,请 Fork 一下 Deploy Freeze 项目,然后该项目将创建一个 CI/CD 流水线,迭代你的项目并应用所需的部署冻结计划。 你可以自定义此项目以适合你团队的工作流程。
提供的项目包含一个 `.gitlab-ci.yml
文件和一个 Python 脚本,旨在自动管理极狐GitLab 组内多个项目的部署冻结。它使用极狐GitLab API 和各种 Python 库来创建和删除部署冻结期,并设计作为 CI/CD 流水线的一部分运行,以确保极狐GitLab 组内部署期间的代码稳定性。
提交更改并将其推送到存储库以触发 CI/CD 流水线。
.gitlab-ci.yml
文件中定义的变量,如下所示:
FREEZE_START
、FREEZE_END
、CRON_TIME_ZONE
和 GROUP_SLUG
的值,然后运行流水线。您可以通过跳到 FREEZE_START
和 FREEZE_END
变量中的下一行来定义多个冻结期。
验证这些部署冻结期是否按预期创建和管理。
检查您的极狐GitLab 群组的项目是否在指定时间段内部署冻结。
你可以按照部署冻结文档来优化组部署功能,该文档概述了设置 .freezedeployment
作业的步骤,该作业可以在存在 CI_DEPLOY_FREEZE
变量时有条件地阻止部署作业。通过包含 .freezedeployment
模板并将其扩展到项目的 .gitlab-ci.yml
文件中,您可以防止在冻结期间进行部署,从而确保代码稳定性。一旦冻结期结束,就可以进行手动部署干预,从而实现整个集团项目的受控和可预测的部署过程。
通过将部署冻结扩展到群组级别,团队可以轻松简化和增强其部署策略,以确保一致性,防止在你指定的时间段内意外发布生产,无论是大型公司活动还是假期。凭借极狐GitLab API、CI/CD 流水线的强大功能以及 Python 脚本的灵活性,群组部署冻结是你跨不同项目维护代码稳定性和可预测性的盟友。