采用DevOps的7个主要障碍,你一定不知道!
尽管DevOps已经相对成熟,DevOps哲学仍然在回避甚至是最著名和最有资源的组织。一份令人震惊的Gartner报告显示,75%的DevOps项目未能实现其目标。
为什么DevOps的失败率如此之高?在实施DevOps理念时,组织面临的共同挑战是什么?如何克服这些挑战?
本篇文章将解决这些问题,并为企业提供可复制的策略,以提高DevOps计划的成功率。
1.资源配置不规范
资源分配是DevOps的一大挑战。仅仅集成开发和运维团队并不能产生一个高效的DevOps团队。极大数量的DevOps团队缺乏主题专家,这严重影响了团队实现DevOps承诺的能力。
首先,从事应用程序开发、优化和监控等不同技术的多面手不会像专家那样有效率。这样会浪费宝贵的时间,最终减慢DevOps的交付速度。
此外,当DevOps团队最小化计划外工作时,他们的工作效率最高。如果没有专门的资源来处理特定的DevOps问题,团队被迫将复杂的问题分配给非主题问题的专家。这将破坏他们的工作计划,并使整个团队效率低下。更重要的是,这类人才日益增加的工作量增加将导致员工筋疲力尽,并有可能使整个DevOps计划脱轨。
只有在有专门人才处理问题时,DevOps才能加快功能发布、更新和上市时间。因此,企业必须确定关键的应用程序技术和开发流程,这些技术和流程可以通过DevOps进行优化,并为这些特定领域分配专门的技能型人才。
最佳的资源分配对于DevOps计划的成功至关重要。
2.责任错位
DevOps将目标截然不同的团队聚集在一起,在一个“不稳定的”环境中工作。开发人员主要关心的是创新、稳定的运维团队、性能完美的QA团队等等。当然,这些团队之间必然会有摩擦和冲突。
更糟糕的是,高层往往不会明确定义DevOps团队的目标、职责和优先级。这给模棱两可留下了很大的空间。习惯于孤岛式工作而不担心依赖关系的团队会倒退到原来的工作方式,从而否定了所有实现无缝协作的努力。
在改变领导者之前,让团队走出思维定势是最大的挑战。因此,当团队由跨学科资源组成时,DevOps的工作效果最好。拥有运维思维的开发人员,他们不羞于经常走出自己的舒适区,这是引领DevOps计划走向成功的迫切需要。
组织通常通过清晰地描述DevOps的目标、优先级和职责来克服这些挑战。更重要的是,他们为DevOps任务的成功分配了完整的责任。每个团队成员都对DevOps端到端任务的成功负责。当他们的个人表现由团队的整体成功来衡量时,筒仓会自动分解,协作会迅速增加。
3.过程割裂
没有多少DevOps领导者意识到,或者至少意识到,DevOps是非常分散的。尽管DevOps已经成熟,但它并不是特别适用于中小企业软件开发和交付模式。DevOps长期以来主要是一个大型企业计划。由于这个原因,与DevOps接轨的中小企业发现自己陷入了困境。
DevOps通过自动化软件开发生命周期中涉及的大部分任务来工作。然而,没有一个工具、过程或资源可以实现这一点。DevOps团队必须使用不同的工具来自动化其操作的不同方面。有很好的工具可以自动化各个组件,比如持续集成、基础设施供应、测试、源代码控制等等。但是,这些工具之间彼此不能集成。
使这些不同的工具相互通信需要大量的资源,而大多数组织无法或愿意分配这些资源。由于这个原因,DevOps团队经常被迫使用有限的自动化功能,这是DevOps的对立面。
高效的DevOps团队在执行任务和自动化任务之间分配时间。如果没有自动化,事务性工作会逐渐增加,导致员工精疲力尽、流程延迟、响应能力恶化和交付质量下降。
企业可以通过开发一个清晰的DevOps策略来避免这些问题,该策略指定组织的DevOps目标,确定可以自动化的流程,并部署资源来实现这些目标。这些目标应该与资源分配相匹配,这种解决碎片整理的现实方法将帮助企业简化和自动化对他们来说很重要的流程。
4.缺乏适当的度量标准
缺少适当的度量标准既是一个过程挑战,也是一个人员挑战。KPI和指标在向DevOps团队传达组织的优先级和期望方面大有帮助。正如前面所讨论的,稳定性和部署时间在DevOps团队中持续存在冲突。是应该以牺牲稳定性为代价匆忙交付,还是注重稳定性延迟交付?是如何开始优先考虑一个目标而不是另一个目标的?
指标为团队提供了明确而精准的方向,以确定不同目标的优先级。尽管这些指标的价值可能会随着业务的不同而变化,但这些指标本身对所有DevOps团队都是普遍相关的。以下是企业在向团队传达DevOps目标时必须定义的一些指标:
● 部署频率
● 部署时间
● 更改故障率
● 自动测试通过率
● 每次发布后的故障数
● 缺陷逃逸率
● 检测的时间到
● 功能使用
● 终端用户体验
● 业务影响
● 部署失败
5.文化转变
对变革的抵制将是DevOps转型的最大障碍。DevOps试图将控制权从各自为政的团队及其负责人转移到组织内的单个多部门机构。自然,这样的尝试可以被解读为对决策权的侵蚀。
更进一步说,这不完全是关于控制。与传统的IT角色相比,DevOps的领导角色有很大的不同。一般来说,IT领导层必须具备在各种技术方面指导、支持和建议员工的专业技能。在DevOps环境中,情况并非如此。DevOps的员工工作在一个不稳定和快速发展的环境中。错误是常见的,而带来的后果可能是灾难性的。这样就不难理解为什么员工会担心DevOps流程。
因此,领导的首要作用是创造培养条件,给予员工更高的自由度,保护他们免受快速试验带来的挫折。此外,领导者的工作必须集中在确定DevOps的成功模式,并复制这些模式,以在整个组织中扩展转换。
一个自上而下的方法试图重新定义领导的角色,赋予DevOps团队更多的实验自由,并确保他们的稳定性,这对于克服文化惯性至关重要。
“无法实施文化变革——整个组织的相关方必须一致支持成功采用DevOps所需的必要文化变革。它包括不同组内的执行人员和领导。这不仅仅是技术上的采用。为了成功,业务、运营、IT、财务和其他方面必须承诺并建立信任。”
6.无法扩展DevOps
很多时候,早期DevOps计划的成功往往会变成失败。表现最好的DevOps团队被更多的项目淹没,这很快就会成为项目交付的瓶颈,更不用说随之而来的压力增加和生产力下降了。
解决这个问题的一个明显的方法是扩展DevOps团队。然而,这说起来容易做起来难。DevOps专家需要与开发人员或工程师截然不同的技能,因此雇佣起来既困难又昂贵。
一些组织通过在每个开发团队中嵌入一个DevOps专家来克服这个挑战。他们的职责是简化各自团队的交付链,同时与其他部门的DevOps专家进行协调。然而,这种方法经常会在团队之间滋生不一致和协作的麻烦。解决这些新问题的一种方法是借鉴开源实践,使用一种内部源代码方法。
团队必须拥有强大的协作工具,使他们能够从世界任何地方进行编码、发布和协作。最后,要用健壮的、去中心化的“以产品为中心”的交付模型取代传统的“以项目为中心”的方法。
“由DevOps驱动的改变首先需要有一个让人信服的目的。然后,要成功地衡量变化,需要整个组织的沟通、协作和承诺。”
7.无法合并安全性
纯粹从表面上看,DevOps和安全性似乎完全冲突。DevOps的核心是速度和持续交付,而安全性则强调广泛的测试和防误。然而,企业正慢慢意识到,与安全性集成的DevOps可以帮助他们修补漏洞、发布更新,并比以往更快地应对网络威胁。
目前,DevOps在将安全集成到其过程中面临三个障碍:缓慢的开发速度、无穷无尽的安全标准和对可见性的威胁。
最后,通过向所有团队成员提供安全数据并方便他们报告,可以提高威胁可见性。根据每个团队成员的角色和职责定制的SIEM仪表板可以在很大程度上为DevOps团队提供威胁可见性。为了使之有效,可以建立一个基于共同绩效目标的奖励体系。
每个组织的DevOps计划都会遇到该组织特有的复杂障碍。然而,关注团队成员的合作和稳定可以减少内部阻力,并将潜在的惰性来源转变为对领导层的变革,从而确保成功。
*该文为翻译文章,原文链接:https://dzone.com/articles/7-major-roadblocks-in-devops-adoption-and-how-to-a
采用DevOps的7个主要障碍,你一定不知道!的更多相关文章
- [转载] DevOps年中盘点:国外最受欢迎的10篇技术文章
本文根据高效运维系列微信群的群友投稿整理而成.“高效运维”公众号作为本系列群的官方唯一公众号,原创并独家首发. 欢迎关注“高效运维”公众号,以免费参加「运维讲坛」每月一次的线下交流活动:并抢先赏阅干货 ...
- Fbric、Ansible、Docker、Chaos Monkey:DevOps工具的年中回顾
Fbric.Ansible.Docker.Chaos Monkey:DevOps工具的年中回顾 [编者按]近日,Cyber Engineering Solutions Group 技术经理 Hasan ...
- 年度十佳 DevOps 博客文章(后篇)
如果说 15 年你还没有将 DevOps 真正应用起来,16 年再不实践也未免太落伍了.在上篇文章中我们了解到 15 年十佳 DevOps 博客文章的第 6-10 名,有没有哪一篇抓住了您的眼球,让您 ...
- 年度十佳 DevOps 博客文章(前篇)
如果说 15 年你还没有将 DevOps 真正应用起来,16 年再不实践也未免太落伍了.国内 ITOM 领军企业 OneAPM 工程师为您翻译整理了,2015 年十佳 DevOps 文章,究竟是不是深 ...
- 全球顶级专家为你解读:什么是真正的 DevOps?
[编者按]本文是 Skytap 内容主编 Noel Wurst 对 DevOps Enterprise Summit (DOES)的不完全综述,内容包括了 Noel 和一些与会嘉宾的思考,旨在勾画 D ...
- 不要错过 DevOps 之父出席的2017 DevOpsDays 北京站!
通过 DevOpsDays 活动,Patrick 将 DevOps 这项伟大的运动带到了地球的东方,带到了北京.同时,他将亲自参加2017年3月18日的 DevOpsDays 北京站,并作精彩演讲. ...
- 一篇文全面了解DevOps:从概念、关键问题、兴起到实现需求
一篇文全面了解DevOps:从概念.关键问题.兴起到实现需求 转自:一篇文全面了解DevOps:从概念.关键问题.兴起到实现需求 2018-06-06 目前在国外,互联网巨头如Google.Faceb ...
- 【转】DevOps的前世今生
转自:http://www.infoq.com/cn/news/2016/09/learn-devops-from-reports 目前在国外,互联网巨头如Google.Facebook.Amazon ...
- Jenkins学习总结(6)——了解DevOps的前世今生
DevOps是什么?从哪里来? DevOps的概念 DevOps一词的来自于Development和Operations的组合,突出重视软件开发人员和运维人员的沟通合作,通过自动化流程来使得软件构建. ...
- DevOps VS 职责分离
原文地址: https://medium.com/@jeehad.jebeile/devops-and-segregation-of-duties-9c1a1bea022e 原文作者:Jeehad J ...
随机推荐
- 深入理解Go语言(08):sync.WaitGroup源码分析
一.sync.WaitGroup简介 1.1 sync.WaitGroup 解决了什么问题 在编程的时候,有时遇到一个大的任务,为了提高计算速度,会用到并发程序,把一个大的任务拆分成几个小的独立的任务 ...
- 如何避免Git合并远程分支时出现可读性差的日志
问题及现象 当某一分支(假设为main)的本地仓库和远程仓库都基于同一个提交进行了修改,并分别创建了新的提交时,在本地执行git push origin main会提示先要执行git pull合并远程 ...
- Python函数每日一讲 - 一文让你彻底掌握Python中的getattr函数
引言 在 Python 中,getattr() 函数是一种强大的工具,它允许我们在运行时动态地访问对象的属性和方法.本文将介绍 getattr() 函数的基本语法.常见用法和高级技巧,帮助大家更好地理 ...
- Html飞机大战(十一): 飞机撞毁爆炸
好家伙,这篇写英雄撞机爆炸 我们先把子弹销毁弄上去 子弹穿过敌机,敌机爆炸后消失,子弹同样也应该销毁,(当然后续会考虑穿甲弹) 然后我们还要把主角碰撞爆炸检测也加上去 因为他们共用一个思路 ...
- 【Azure API 管理】如何修改Azure APIM的管理员邮箱和组织名称
问题描述 当创建一个新的APIM服务时,会要求输入组织名称(Organization name)和管理员邮箱(Administrator email :Set the e-mail address t ...
- 笔记本linux问题记录
目录 UEFI笔记本无法引导进入操作系统 grub引导错误,无法进入系统 笔记本亮度不能保存 禁用独立显卡 KVM 解决nmcli dev 中的wlan0显示unavailable 杂项 UEFI笔记 ...
- 利用微软官方API实现Office文档的在线预览功能
随着互联网时代的飞速发展,越来越多的工作开始依赖于云端服务,我们的办公方式也逐渐发生了翻天覆地的变化.在这种背景下,急需一种无需本地安装Office软件,就能快速查看和共享Word.PowerPoin ...
- Jmeter参数化-用户自定义变量
一 首先我们先来了解下jmeter 做参数化的目的: 1通过参数化来集中管理配置和测试数据 2通过参数化实现数据驱动测试 二 线程组添加配置元件中的用户自定义变量 添加变量名称,变量值 三 使用变量 ...
- Java基础全程复习笔记(值得参考)
Java基础复习笔记 第01章:Java语言概述 1. Java基础学习的章节划分 第1阶段:Java基本语法 Java语言概述.Java的变量与进制.运算符.流程控制语句(条件判断.循环结构).br ...
- aardio 嵌入 其他应用程序
aardio 嵌入 其他应用程序 需求 这个chrome壳不能进行拖拽和缩放,所以再套一个壳,可以再分屏的时候用 import win.ui; /*DSG{{*/ winform = win.form ...