为什么要在提交上打标签来创建发布版本?

44次阅读
没有评论

问题描述

在进行新的持续集成/持续交付(CI/CD)流程搭建时,正在用GitHub Actions代替Jenkins-X 2。在查看了许多用于创建发布版本和变更日志的操作后,他发现很多操作都是通过在提交上打标签来触发工作流程的。目前,他通过在主分支上的每次推送(合并的Pull Request)都创建一个新的发布版本,使用符合约定的提交信息打上版本标签(例如v1.0.0)。

用户想要了解的是,为什么他或者领导团队需要手动创建标签来生成新的发布版本和变更日志?背后的逻辑是什么?

解决方案

请注意以下操作可能因版本差异而有所不同。确保在操作之前做好备份。

手动创建标签以运行发布流程的好处

创建标签手动运行发布流程(包括变更日志)相比完全自动化整个流程有其优势,这些优势可能包括:

  1. 清晰的变更日志: 手动创建标签意味着你需要仔细考虑应用的哪些变更。这会促使你编写更清晰的提交信息,以便在变更日志中准确反映每个提交的内容。这可以帮助团队和用户更好地了解每个发布版本的改进和修复。

  2. 调试问题更方便: 变更日志使得可以点击特定版本并将其与先前版本进行比较。这有助于在应用中应用变更时更轻松地调试问题。当应用出现问题时,你可以迅速确定是否是由于某个特定变更引起的,从而更快地找到解决方法。

  3. 避免发布频率过高: 如果每次合并都自动创建发布版本,可能会导致发布版本数量过多。这可能会让版本控制和发布管理变得混乱,尤其是在项目变得复杂时。手动创建标签允许你在合适的时机选择创建发布版本,以避免过度频繁的发布。

  4. 适应团队流程: 不同团队可能对发布版本的要求不同。手动创建标签允许团队根据自己的工作流程和需求来灵活管理发布。这可以帮助团队更好地控制版本发布的时间和内容。

自动化整个流程的考虑

虽然手动创建标签具有其优势,但也可以考虑完全自动化发布流程的方式。这种方法适用于团队希望快速、持续地发布新版本,特别是在CI/CD流程中。

以下是一些考虑自动化整个流程的情况:

  1. 快速发布: 自动化发布流程可以在每次合并或推送到主分支时快速生成新的发布版本。这有助于实现持续交付,使新功能和修复能够更快地到达用户手中。

  2. 减少人工操作: 自动化流程减少了手动创建标签的步骤,降低了出错的风险,并减少了人工操作的工作量。

  3. 保持一致性: 自动化流程可以确保每个版本的发布流程都是一致的,避免了人为因素对发布过程的影响。

  4. 自动化测试和部署: 自动化流程可以集成测试、构建和部署步骤,从而实现从源代码到可部署的应用程序的端到端自动化。

总的来说,选择手动创建标签还是自动化发布流程取决于团队的需求、流程和偏好。手动创建标签可以提供更精确和可控的发布过程,而自动化流程则可以实现更快速的交付和部署。最佳实践可能是在两者之间找到平衡,根据项目的特定需求来决定何时手动创建标签以触发发布流程。

正文完