探索ITIL和DevOps的边界
《探索ITIL和DevOps的边界》要点: 其实在今天的运维领域,ITIL和DevOps之间的冲突还是蛮明显的,有些是表现在产品上,有些是表现在思维/理念上.ITIL在产品上以流程为核心目标的设计,很难满足自动化的要求,DevOps极力推崇工具/平台/自服务文化;理念也是如此,ITIL以流程为先介入到一个企业的IT过程.本质上来说,这两者不是同一个东西,但聚焦到运维领域,这个问题值得对比探讨一下. 在EXIN官方给的DevOps最新框架中,把很多因素糅合到了一起,对于整个产品生命周期来说,可以看到几个典型的阶段,如敏捷管理、持续交付、IT服务管理. 当然这篇文章不是简单的从DevOps与ITIL的全/子集的关系来探讨,那样就可以直接下结论,退出讨论作罢. 首先让我们来看看持续交付所声明的原则:
其中有一条讲——“将几乎所有事情自动化”,持续交付覆盖了【部署】和【运营】两个运维相关阶段.在过去,我也一直强调运维其实也是在做交付,其实也是由此而来.那么什么是部署自动化?什么是运营自动化?自动化部署,就是通过部署平台,把相应的变更推送到开发、测试和生产环境,不依赖某个人或角色来执行.这里面就强调的部署平台能力是针对所有环境——开发、测试、生产等等,并且要支持灰度部署、蓝绿部署等等.运营是服务线上运行阶段,这里面包含了监控、服务变更、服务优化、容量预测与规划等等. 其实IT运营和产品运营有很多的类似之处,只是两者看到了对象的不同,一个是IT对象,一个是产品对象.所谓运营都是在建立一套服务流程或过程(有ITIL部分),整合公司内外有限的资源所展开的一系列活动,以便更好的服务客户.狭义的IT运营可以理解成维护,广义的IT运营可以包含产品体验优化、用户满意度提升、应用性能管理、安全、质量控制等等,质量控制算是IT质量运营的一个维度. 既然在前面讲到了自动化的原则,那么针对运营过程的自动化到底该如何做?如下图: 两种流程如何结合,有三种模式: 模式一:每一个流程节点都需要调度一个执行工具去作业. 模式二:审批流完成之后,执行流程才得以进行. 模式三:在执行流程中设置一个节点,定时去check管理流程的审批状况.
今天思考DevOps,要用结果来定义你的IT模式是不是DevOps,比如说版本交付周期,故障恢复能力等等,这一定是效率优先的.同样我们思考ITIL流程实践,也要兼顾效率,带着工具思维去简化流程.不可否定,他们有各自存在的价值和场景,用管理和执行的方式来定位,至于流程的模式,我也总结了三种供参考. @ITIL是面向管理过程的;DevOps是面向IT运营过程的. @ITIL是规则引擎;DevOps是执行引擎. @ITIL是强调规范的;DevOps是强调敏捷的. @ITIL是以离线任务管控为目标的;DevOps则以在线服务管理为目标的. @ITIL不等于追求稳定;DevOps更不是以牺牲稳定而一味追求效率. …….. 原文出处:https://www.easyops.cn/news/78 (编辑:ASP站长网) |