DevOps核心原则

Stella981
• 阅读 631

DevOps核心原则

如果让三个人描述DevOps,您将得到四个不同的答案。有时,从事运营工作的开发人员被称为DevOps。其他人则说这与基础架构和部署的自动化有关。有时,您可以看到DevOps是sysadmins的现代化标签。我们可以看到该术语很流行。那到底是什么呢?什么是DevOps?

DevOps核心原则

DevOps_的第一种方式_是通过组织中各个职能领域(从收集需求到生产中的软件运维)创建平衡稳定的工作流程。重点放在整个系统的全局目标上,而不是单个部门的局部目标上。为了使概念更清晰,让我们看几个关键要点。

1.1减少批次大小

进行中(WIP)是已开始但尚未完成的工作量。大量在制品是多任务处理的标志,并且会阻碍工作流程。为了限制在制品,我们应该减小批量大小。这个想法源于精益制造。大批量生产零件在制造业中很常见。设置新机器并在工作之间切换既昂贵又费时。因此,在设置好机械之后,尽可能多地制造零件被认为是可行的。

例如,一家汽车生产厂将生产大量的车身面板以减少转换次数。但是,这会产生大量的WIP。工作流程的可变性在整个制造工厂中级联,从而导致更长的交货时间。想象一下,如果在组装汽车时在车身面板上发现缺陷,会发生什么?最有可能的是,整个批次必须被丢弃和再生产。批量生产会延迟反馈,如果出现错误,则必须重做更多工作。

DevOps核心原则
同样的想法适用于软件开发。但是,我们正在处理代码,而不是机械和车身面板。对版本控制的每次提交都会增加软件开发价值流中的批处理大小。

一个典型的例子是年度生产部署计划。如果每年进行一次部署,则批处理量很大。一步就可以部署一年。与汽车厂类似,如果出现任何问题,则必须将整个批次回退。然后必须付出更多的努力来重做被认为已完成的工作。而且要发现并解决导致部署失败的问题,例如6个月前,就具有挑战性。

DevOps核心原则

使用寿命较长的特性分支时,可能会遇到类似的问题。分支保持隔离状态的时间越长,看到的更改越多,批处理大小就越大。随着时间的流逝,将其集成回主干变得越来越困难。合并冲突的可能性很高。由于反馈被延迟,因此返工的可能性很高。这些因素破坏了工作流程并增加了部署前置时间。

DevOps核心原则

为了缩短部署的交付时间,我们必须减小批量大小。不建议使用长期存在的功能分支。如果我们尽早集成并且以较小的增量部署软件,则可以获得更快的反馈。如果我们继续减小批处理的大小,我们最终将达到单件流,其中每次提交都会流经整个软件开发价值流。一旦所有自动检查都通过,更改将最终投入生产。

能够实现这一目标的团队将利用基于主干的开发持续集成持续交付持续部署等实践。他们在测试自动化方面进行了投资,并为低风险版本设计了他们的软件。他们还组织了自己,以使所需的移交次数最小化。交接需要沟通和协调。不幸的是,即使在最好的情况下,一些知识也会丢失。这是一个潜在的错误点,错误可能蔓延,工作可能堆积起来,从而中断流程并增加部署提前期。

1.2消除约束

不断发现和消除我们工作中的限制是提高产量和减少交货时间的关键。Goldratt博士在《超越目标:约束理论》中指出

在任何价值流中,总是有一种流动的方向,并且总是只有一个约束。在这种约束下没有做的任何改进都是一种幻想。

技术价值流的一个例子是_环境创造_。如果建立测试环境需要花费数小时,那么在价值流中进行的任何改进工作都是一种幻想。

DevOps核心原则

例如,如果我们将构建时间从10分钟减少到3分钟,则构建速度会更快。但是总体上没有什么事情做得更快。创建环境仍然是一个障碍。更糟糕的是,WIP增加了。现在,新版本的堆积速度甚至更快,等待部署到测试环境。由于创建环境会阻止新的工作顺利进行,因此在我们应该在价值流中找到约束,将其消除,然后找到下一个约束。

更多精彩: 我的课堂: https://edu.51cto.com/sd/8311a

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
MSTP+VRRP+OSPF+双出口
拓扑图!MSTPVRRPOSPF双出口(https://s4.51cto.com/images/blog/202012/14/3e101c381bc712f9915994275649ac00.png?xossprocessimage/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFF
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
5步实现数据指标增长,提升数据分析能力
!5步实现数据指标增长,提升数据分析能力(https://s4.51cto.com/images/blog/202009/15/081547a226ce35f8ee53d7e5675f38cb.png?xossprocessimage/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_10
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这