当前企业都在追求可持续的、快速迭代的软件工程发展,如何实现从一个需求到交付快速落地,这一切都要求企业具备快速响应的能力,这正是推动持续集成、持续交付、持续部署的动力。
1、用户的诉求或问题
发布问题:企业发布需要投入大量精力,很多都是晚上升级,员工得通宵加班,还无法保障升级不出现问题,不具备快速大批量部署的能力;
版本追溯:为了保证版本可追溯,我们需要保存各个历史版本,如何实现出错后能够快速回滚;
质量守护:缺乏统一的研发平台,自动化程度低,没有有效的质量保障体系,基础设施保障的建设往往落后于企业的快速发展;
2、云效+主机部署解决方案
结合云效持续交付流水线和主机部署的能力,为应用持续交付提供了很好的基础保障,如图:
开发者提交代码变更到代码库,云效在监听着代码库的变动,一旦代码发生变化,将自动触发云效持续部署流水线一次构建任务的运行,包括代码检查、构建、测试部署、测试验证和生产部署等过程。其中,在构建完之后,生成制品包并自动上传至OSS仓库,在部署阶段(测试环境的部署和生产环境的部署)时,再从制品仓库中取得最新的版本,根据不同的部署策略通过主机部署到不同环境,这里资源可以是阿里云或者自建主机资源。
以下,我们将分步骤介绍如何快速配置这样包含云效和主机部署的持续部署流水线。
3、云效+主机部署操作指南
通过以下步骤快速创建基于云效和主机部署流水线;
立即体验:云效流水线Flow
新建流水线
进入流水线应用,点击右上角【新建流水线】,选择对应的开发语言,选择"测试、构建、部署到阿里云ECS/自有主机" 模板,即可快速使用主机部署发布能力。
点击创建,完成初始化流水线,此时弹出新建代码源,选择代码服务和输入代码仓库地址,点击保存。
编辑流水线
构建制品:可以为制品选取一个名称,在流水线中的后续阶段任务中可以使用”构建物上传“中配置的制品。
主机部署:这里的【新建主机组】是指运行在不同环境的机器资源,例如:集成测试环境(通常称作日常环境)、预发环境(称作预发环境)、对外提供服务的环境(称作正式环境)等不同的环境里运行。
云效支持两种主机组:阿里云ECS和可以出公网的非阿里云主机;
阿里云ECS部署请参考:阿里云ECS
公网主机部署请参考:公网主机部署
部署配置:在主机部署任务中,可以进行部署相关的配置,用于将构建产物在部署机上进行安装。
详细部署配置请参考:部署配置
部署策略:主机部署过程中,可以制定对应的部署策略,提供了分批发布和灰度发布的能力;
运行流水线
点击流水线编辑页面右上角【运行】,流水线会自动保存并开始运行;
部署详情:流水线运行页面,主机部署任务中,可以点击【部署详情】查看部署过程。
回滚方式:流水线所有执行的部署历史记录,并可选择其中任意一条历史记录进行回滚操作。
查看测试报告
点击流水线页面各阶段测试报告,可以查看详细的测试结果进行分析;
3、云效+主机部署流水线进阶
上一节介绍了流水线基本操作,在实际部署操作中可以根据需要完善流水线,增加更多验证和卡点,例如:
流水线1: 持续验证流水线:(测试环境主机部署)
流水线2: 持续发布流水线:(生产环境主机部署)
流水线定义了持续交付过程的各个步骤和卡点,通过执行流水线1和流水线2即可完成从代码提交到正式发布的持续交付过程。