CICD - 持续集成与持续交付

持续集成与持续交付是软件开发和交付中的实践。我们项目中一直在践行持续集成(CI:Continuous Integration);持续交付(CD:Continuous Delivery)未能达到理想状态,只能实践一部分。这篇文章用于总结CI/CD的实践。

持续集成

 

CICD - 持续集成与持续交付

 

 

什么是持续集成?

软件开发中,集成是一个很可能发生未知错误的过程。持续集成是一种软件开发实践,希望团队中的成员频繁提交代码到代码仓库,且每次提交都能通过自动化测试进行验证,从而使问题尽早暴露和解决。

持续集成的好处是什么?

持续集成可以使问题尽早暴露,从而也降低了解决问题的难度,正如老马所说,持续集成无法消除bug,但却能大大降低修复的难度和时间。

如何做到持续集成?

首先,持续集成需要:

1. 单一的代码仓库,团队成员都像该仓库提交代码;

2. 自动化构建且构建过程需要包含自动化测试;

3. 有单独的集成机器用于构建;

4. 保证构建速度不要太慢(曾经有一个项目构建需要20分钟,就会很痛苦);

5. 在类产品环境进行测试;

6. 能够方便获取最新的可执行程序;

7. 可视化,大家都能看到构建过程及结果;

8. 自动化部署。

其次,我们通过以下步骤进行持续集成:

1. 程序员将代码下载到本地,并在完成修改后提交代码;

2. CI服务器监测代码库,并在有提交时自动触发;

3. CI服务器对代码进行构建,运行单元测试和集成测试;

4. CI服务器发布可部署的artefact用于后续测试,并加上本次构建版本的标签。

5. CI服务器通知团队构建成功或者失败;失败发生时团队需要尽快修复,以免耽搁后续的持续集成过程,因为失败时处于持续集成的暂停阶段。

最后,需要就团队责任达成共识:

1. 频繁提交;

2. 提交之前确保测试通过;

3. 不在持续集成失败时提交代码;

4. 提交代码后保证持续集成成功,不然不准回家

上一篇:浅谈CICD持续集成、持续部署的流程(转)


下一篇:【华为云实战开发】9.如何进行PHP项目的快速搭建并实现CICD?【华为云技术分享】