在技术团队里,如何达成DevOps共识?落地好难
DevOps是一个复杂的多维话题。这是上下文相关的。那些试图了解和实施DevOps的人将他们的角色和文化观点带入了流程。意见和专业知识的多样性可能是重要的优势。但是,这也可能导致开发DevOps共识产生摩擦和争论。按我的个人经历,在团队里,想要推动DevOps发展和落地是很痛苦的,特别是在小团队里,因为这将是一场颠覆的变革。你可以喷我,但我不赔钱。 为什么需要DevOps达成共识? 需要共识,因为DevOps不仅是一回事。这是一整套解决广泛问题的想法。任何共同解决问题的团队必须首先同意:
想要使用DevOps回答这些问题的企业和团队必须首先就以下两个问题的答案达成共识:
每个企业想要完善或升级自身的运维体系,都必须问自己这些问题才能开始使用DevOps,并且每个企业的答案都不同。进行自我询问和回答的过程可以知道什么有效,什么无效,以及可以采取哪些措施来促进有效的变革。 首先,DevOps讨论 正在考虑DevOps的企业应首先讨论什么是DevOps以及如何使用它。有很多关于DevOps的学习资源(有关更多示例,请找度娘或者关注并私聊我)如果你承担着促进讨论的任务,那么你很幸运,有许多有效的方法可以引导对话。你的第一步是研究。对基本概念的理解将使你能够将其介绍给各种各样的利益相关者。 “领导对话”并不一定意味着“向同事介绍DevOps。”要达成DevOps共识,你的首要任务是打下基础,然后让讨论有效地进行。作为协作的“发现”会话,第一次对话将更加有效。对话负责人往往更有效地作为教练和裁判,而不是教育者。介绍基本思想,然后通过聆听和提问来促进对话。 如果你准备在DevOps上做演示,我建议你在简介的开头限制使用“ DevOps”一词。这个词可能充满了成见,特别是如果你的听众对DevOps接触很少。重点关注基本原则,重点在于如何将其用于解决特定问题。尝试避免和阻止对DevOps的简化定义。你会听到类似的声音:
这些是快速形成意见的示例,但并未完全理解DevOps的广度和深度。DevOps涉及自动化,流程改进和配置管理等等。使用严格规定的处理方式,不应将DevOps视为正统观念。应该将其视为用于实现业务目标的一组工具。 随着对话的进行,记录关键问题。最关心的业务是什么?列出这些问题的优先顺序。该过程将使小组专注于最关键的业务挑战。一旦达成共识,即可将DevOps评估为解决这些问题的工具。 如果你的企业正在考虑对DevOps进行大规模战略采用,则你的DevOps共识讨论将需要跨多部门的领导团队参与:
这些角色各自具有独特的视角。确保代表每个角色,并有机会表达关切和提出问题,这一点至关重要。公开的讨论将使这个跨职能团队可以考虑所建议方法的折衷方案,并平衡所有角色之间的关注点。该团队应该在工作会议上一起学习DevOps,以开发对你的企业有意义的DevOps定义。 那么,什么是DevOps? DevOps不仅是一回事,因此很难编写一个单一的,包含所有内容的单句定义。DevOps有很多东西,而且这些东西还可以解释。这并不意味着尝试定义DevOps是徒劳的。恰恰相反,DevOps建立在一些非常成熟的概念上。这些想法和原则为DevOps的实施方式提供了依据,但它们并不是通往“ DevOps必杀技”的路线图。它们是指南,是思考问题和解决方案的方式。 在团队中达成DevOps共识的第一步是以通俗易懂的语言向同事介绍这些基本思想。为了使讨论首先围绕目标而进行,然后再讨论方法,请以这些基本思想为重点开始介绍。 以下是一些DevOps的首要原则,可帮助你达成DevOps共识: 简短的反馈循环:敏捷使用诸如站立式的仪式来确保开发人员和利益相关者之间的定期沟通。DevOps还强调缩短和放大反馈回路。 精益IT:精益IT的原理主要集中于消除生产中的浪费。DevOps是在控制过量生产和提高生产流程效率方面发挥了作用。 约束理论:约束理论提供了一种通过识别和“打破”(消除)约束的连续过程来提高吞吐量的方法。约束定义为多步骤生产过程中的任何“瓶颈”步骤,其中工作变慢并开始积压。敏捷实践将工作流程可视化,有助于揭示工作障碍。DevOps将这种想法从软件开发生命周期扩展到整个软件交付生命周期。 价值流图:所有服务都是通过不同复杂的过程生产的。一个人很少了解复杂的过程。每个步骤(在制造中称为“工作站”)通常由具有专门技能的员工来处理。软件开发工作站包括开发,测试,部署和维护。 理想情况下,创建价值流图是一个协作过程。每个团队汇聚一堂,讲述他们在生产中的故事,这将有助于达成DevOps共识。整个故事源于价值流图的过程。此练习通常会暴露整个过程的效率低下。DevOps使用“价值流图”将生产工作与战略性企业目标保持一致。 持续改进:持续改进是一种寻求并消除过程中效率低下的科学实践。持续改进团队不断评估生产团队的过程和结果。关于约束或其他低效率如何影响生产的理论得到了发展。然后,团队对流程进行细微的更改,并测量改进(或缺少改进)的过程。这个过程永无止境,一直在寻找消除浪费和提高生产率的机会。DevOps从业人员使用持续改进作为一种整体测量和改进软件交付过程的方法。 你将学到的大多数关于DevOps的知识都植根于这些基本概念中的一个或多个。在DevOps讨论中采用“自下而上”的方法将使人们对第一个原则产生共同的共识。共同的理解是下一步的强大平台:弄清楚如何使DevOps适应企业的独特需求。 企业如何适应DevOps? (编辑:ASP站长网) |