根据《 2020年DevOps状况报告》,DevOps自动化已经跨越私有和公有云环境,并包含监视,警报,审核以及连续,渐进式交付。这种自动化,支持DevOps实践和Kubernetes架构,旨在帮助DevOps团队更高效地开发和发布高质量,安全的软件,从而为组织创造更高的商业价值。
但是,挑战也很多。
DevOps的主要挑战
通过了解,在采用DevOps和可扩展性方面,面临的一些主要挑战有:
- 每个失败的部署,都需要大约五个小时的修复,并需要进行六次重试才能正确完成。
- 复杂的流水线,维护困难。
- 持续交付中,大约80%的时间用于人工质量审计。
- 故障排除中,的大约90%的时间用于人工修复。
为什么会这样呢?为什么部署会占用大量时间和资源?为什么如此多的组织无法释放DevOps的真正潜力,无法更快地开发出更好,更安全的软件?
为了回答这些问题,我了解和确定了一些关键因素,这些因素扼杀了整个组织中DevOps的采用和可扩展性。
阻碍DevOps采用和扩展的7个瓶颈
- 缺乏多云可观察性:对混合云和多云环境的有限访问和可见性,掩盖了DevOps采用的真实状态。对环境的可观察性越差,在组织内成熟和自动化的DevOps实践的难度就越大。
- 对传统工具的依赖:微服务与单体应用程序不同,但是许多团队仍在使用相同的传统工具进行软件交付。
- 对传统流程的依赖:同样,并非所有微服务都是平等的,但是组织通常会在整个流程中应用顺序的,瀑布式的开发流程,就好像它们是平等的一样。
- 紧密耦合的体系结构:某些组织结构和流程导致紧密的体系结构耦合和相互依赖的系统,从而使内部扩展DevOps更加困难。
- 定制:存在大量定制化产品。
- 缺乏标准:缺少统一标准指导实践。
- 缺乏自动化:忽略了对自动化操作的需求。
Keptn应用而生
这些瓶颈,背后缺少的是端到端的可观察性,自动化和AI,以推动数据驱动的交付和编排。
这些需求激发了一个名为Keptn的开发,该项目是基于事件的控制平面,用于云原生应用程序的连续交付和自动化操作。
使用数据驱动的声明式编程方法进行编排,Keptn消除了将流程放入脚本的需求。基于GitOps,服务级别目标(SLO)和开源互操作性标准(例如用于与工具进行通信的CloudEvents),Keptn实现了持续交付和自动修复。
前面我们提到:流水线中约95%时间都花费在扩展流程,更改工具以及修补程序上。所有这些都是因为传统流水线太复杂而无法扩展。
在这种情况下,解决方案是删除硬依赖性和自定义集成。通过将流程(例如构建,准备,部署,测试,通知,回滚)与工具(例如配置,管理,部署,回滚,监视,测试和ChatOps)分开,团队可以使用事件驱动的体系结构连接这些流程和功能。
基于Keptn的业务流程范例,可以在整个组织中快速扩展和采用这些DevOps流程。
解决DevOps瓶颈的7种方法
以下是Keptn解决上述DevOps采用和可伸缩性挑战的七种方法:
- 专为多云而构建:Keptn专为现代云原生和现有企业技术而设计。
- 灵活的工具编排:无需使用旧版工具进行交付,而是根据组织的独特的体系结构来编排所有工具。
- 适应性强的流程:它不会在所有微服务中应用相同的旧流程,而是应用最适合的流程。
- 解耦的体系结构:Keptn没有紧密耦合的相互依赖性,而独立于底层基础结构来运行流程。
- 与定制无关:开放的集成标准可确保与所有DevOps工具的连接,而无需指定供应商。
- 明确的标准:使用标准化的SLO进行数据驱动的生命周期编排。
- 专为自动化而构建:针对先前专注于自动化交付而不是运维的模型,Keptn进行了协调。
DevOps的目标是更快地发布更好,更安全的软件。采用和扩展DevOps流程的瓶颈,使太多团队无法实现这种方法的全部优势,并且限制了团队将其运维提升到更高水平的能力。
为了改变工作方式,并促进更有效的协作,更快的创新和对业务的更积极影响,DevOps团队需要能够利用自助服务平台模型来进行数据驱动的交付和业务编排(例如Keptn),以扩展DevOps的交付。
登录后评论
立即登录 注册