在本第四章的"DevOps 教程"系列中,我们将介绍CI/CD整合的概念和实践。我们会介绍DevOps所带来的好处,包括团队协作、开发效率和产品交付速度的显著提升。
我们还将讨论在DevOps中的不同角色,并理解每个角色在持续集成和持续交付中的关键作用。通过了解这些角色,我们将更好地理解如何构建一个高效的DevOps团队,并实现更好的研发效能。
最后,我们将介绍在生产环境中常见闭环流水线的流程。
本系列将探讨 通过 OCI DevOps Services 自动化构建OKE的整个流程,介绍它们的流程和作用:
- 基础架构流程 && OCI 代码仓库使用
- Build Pipeline (CI)
- Deployment Pipeline (CD)
- 整合 CI/CD
通过本系列的文章,您将了解如何在 OCI DevOps Services 中搭建自动化流水线,提高应用开发和交付的效率,同时充分发挥 OCI 云原生服务的作用。
每一次流水线的执行,都是一个完整的业务闭环,确保每次上线都是有迹可循且及时反馈的过程。
1 什么是 DevOps
维基百科定义: DevOps是一套将软件开发和信息技术操作相结合的实践,旨在缩短系统开发生命周期,打破开发与维护之间的壁垒,从而提供透明且高质量的交付过程。
2 DevOps带来什么
1. 变更可控
在DevOps实践中,变更的可控性是关键因素之一。通过使用版本控制系统,团队可以追踪每次变更,确保代码更改得到透明、可控的管理。同时,通过自动化测试和集成,确保每次变更都是对某个业务请求的响应,从而提高变更的质量和可追溯性。
2. 任务自助
可视化流水线设计与配置使得任务自助成为可能。团队成员可以通过简单的界面设计和配置流水线,从而降低了操作的技术门槛。流水线的持续运行保障了安全、方便和快捷的交付流程,同时也大大提高了效率,减少了人工失误的可能性,使工程师能够更专注于创新和问题解决。
3. 内建质量
强制的代码扫描是内建质量的一部分,它通过自动化工具来检测潜在的代码质量问题,降低技术债务带来的风险。通过在流水线中嵌入质量门禁,可以在每个阶段都强制执行质量控制,从而确保交付的产品具有高质量的代码。
4. 质量改进
质量改进不仅仅是发现问题,更是通过持续的度量和分析,找到问题的根本原因并加以改进。将质量门禁嵌入流水线,可以在每个变更点上执行质量检查,从而及时发现和解决问题,降低技术债务。通过实施大屏看板,团队可以实时监控流水线的运行状况和业务指标。建立度量指标持续修改机制,能够根据团队的需求灵活调整度量标准,从而更好地适应业务的变化。这有助于推动研发效率和交付质量的持续提升,同时也为全团队提供了一个共享的可视化工具,促进更好的协作和决策。
3 角色收益
1 产品经理
- 更快的交付速度: DevOps实践使产品经理能够更快地推出新功能和改进,加速产品交付周期。
- 更频繁的变更速度: 快速迭代和部署意味着产品经理可以更频繁地进行变更,满足市场需求和客户反馈。
2 开发人员
- 采用自动化减少重复性工作: 自动化流水线可以自动执行重复性和繁琐的任务,使开发人员从手动工作中解放出来。
- 更多时间的开发创新: 减少手动工作和快速的交付周期为开发人员提供了更多时间专注于创新和新功能的开发。
- 更高的代码质量: 强制的代码扫描和内建质量控制确保了高质量的代码交付。
3 运维人员
- 更快的修复速度: 快速的部署和自动化流程使运维人员能够更迅速地响应和修复问题。
- 更低的故障率: 自动化测试和持续集成确保了高质量的代码,从而减少了潜在故障的发生率。
- 管理复杂度下降: 自动化流程和一致性的环境配置减少了系统和应用的管理复杂度。
4 测试人员
- 可度量的指标增进了解决问题的速率: 持续集成和度量指标使测试人员能够更迅速地定位和解决问题。
- 更快的发现问题,避免线上问题: 自动化测试和持续集成确保了更早、更频繁的问题发现,从而降低了线上问题的风险。
5 客户
- 更好的体验: 更快的交付和迭代周期意味着客户可以更快地体验到新功能和改进,提升整体体验。
- 更快的迭代: 快速的交付和反馈循环使客户能够更快地享受到产品的不断改进。
4 研发效能大屏
1 语言栈统计
- 目的: 统计项目中使用的编程语言及其比例,帮助团队了解项目的技术栈分布,为技术决策提供数据支持;
2 代码提交量
- 目的: 跟踪代码提交的数量,帮助团队了解开发活跃度和工作进展;
3 代码特征统计
- 目的: 分析代码质量和结构,帮助团队了解项目的代码健康状况。通过各种提交规则帮忙我们更好的了解代码当前特性,如 feat, fix, perf 等前缀特性;
4 开发者提交量统计
- 目的: 跟踪团队中各个开发者的贡献度,了解团队成员的工作情况。
5 开发者提交部门
- 目的: 将开发者的提交按照部门进行分类,帮助团队了解各个部门的工作分布和贡献。
5 常见闭环流水线
每一次流水线的执行,都是一个完整的业务闭环,确保每次上线都是有迹可循且及时反馈的过程。
1 集成工单
- 创建工单: 针对每一次上线,通过集成工单(JIRA, 禅道..)系统创建相应的工单,记录上线的目的、内容和计划。
- 工单分配: 将工单分配给负责的团队或成员,明确责任和任务。
2 邮件通知
- 通知流程: 建立邮件,微信或企业通讯通知流程,确保关键的上线信息能够迅速、准确地传达给相关团队成员。
3 公司业务标准
- 遵循标准: 每次上线都应符合公司的业务标准和最佳实践,确保代码、功能和交付流程符合公司的质量和安全标准。
- 持续改进(CI): 业务标准应当是一个持续改进的框架,通过每次上线的经验教训,不断更新和优化标准。
4 业务闭环
-
追踪上线过程: 利用集成的工单,通知和DevOps系统追踪上线过程,确保每个阶段的任务都得到完成。
5 及时反馈和工单闭环
- 监控和报警: 配置监控系统,及时发现潜在问题并触发报警,确保对问题的迅速响应。
- 工单闭环: 任何上线引起的问题都应该生成新的工单,确保问题被记录、分析和解决,形成工单的完整闭环。
6 总结
这个系列的四次分享为您介绍了Oracle Cloud Infrastructure上利用OCI DevOps Services构建自动化流水线的关键步骤。从构建基础架构、使用OCI代码仓库,到创建自动化构建和部署流水线,再到CI/CD的整合,系列内容提供了直接可操作的指南。
关于推进运维产品的个人观点:
推进运维产品在一些公司较为困难,主要因为运维产品更倾向于以工具的形态存在,而非完整的产品。此外,对于规模较小的团队,构建和落地运维产品需要更大的决心和高水平的运维能力。因此,对于有将运维产品化的运维,建议寻找更大更标准的运维团队…
🚀 炸鸡物料库 🚀
🔍 内容定位: IT技术领域,云计算、云原生、DevOps 和 AI 等相关的技术资讯、实践和经验分享。面向开发、系统和云计算,提供实用的技术内容。
🎯 目标受众: 面向开发者、系统管理员和云计算从业者,提供实用的技术内容。
🗓️ 更新频率:每周更新,每次分享都为您带来有价值的技术内容。
🤝 互动与反馈: 鼓励读者留言、评论,有问题随时提问,我们将积极互动并提供帮助。
💌 订阅方式: 扫描二维码或搜索“炸鸡物料库”关注,不错过每一篇精彩内容。
🌐 合作与分享: 如果您有技术分享或合作计划,欢迎联系我们,共同成长!