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