什么是 DevOps?看这一篇就够了!

news2024/10/7 18:30:36

目录

一、前因

二、记忆

三、他们说……

3.1、Atlassian 回答“什么是 DevOps?”

3.2、微软回答“什么是 DevOps?”

3.3、AWS 回答“什么是 DevOps?”

四、DevOps 文化

4.1、什么是文化?

4.2、什么是 DevOps 文化?

4.3、领导与激励

五、总结


 

一、前因

        我是一个“DevOps 工程师”,于是总会遇到有人问我:“什么是 DevOps?”

        这个问题看似特别基础,基础到很多人懒得回答。但其实冷静一秒,问自己一句“什么是 DevOps?”可能每个 DevOps 工程师都知道“什么是 DevOps”,但是他们给出的答案不尽相同。

        所以我会怎么回答这个呢?下面我们展开来聊聊。

特别强调:本文仅代表我个人现阶段的粗浅认知,本文观点不代表思码逸公司也不代表 DevStream 团队。

二、记忆

        我第一次看到 DevOps 这个词,大概是在2016年的秋天。那时候我在 H3C 从事云计算研发相关工作。记得我接到的第一个任务是研究 OpenStack 的一个 CICD 相关的组件,叫做 Solum,那是我第一次知道什么是 CICD,第一次看到 DevOps 这个词。没错,只是看到 DevOps,但是我无法记住 DevOps 的定义。或者说,当时我甚至没有找到一个清晰易懂的关于 DevOps 的定义。可能很多人和我当年一样,对 DevOps 的印象,就是 Dev + Ops

        2018年的夏天,我开始在太保成研任云平台 PaaS 组负责人,兼任太保云 CMO(Configuration Management Officer) 一职。没错,我依旧是一个“云平台研发工程师”,但是再一次与 DevOps 结缘。太保云的 CMO,简单说就是负责太保云平台的源码管理、研发协作流程、版本管理、CICD、制品管理、发版流程等等。这个时候我其实已经开始研究一些 DevOps 相关的工具了,比如 GitLab、Jenkins、禅道、Artifactory、Nexus 等等;同时也在主导一些 DevOps 文化层面的建设,比如怎样的模式或行为在团队里是被鼓励的,怎样的事情是被禁止的…… 不过我只是在制定规则,而没有意识到这是“文化”。总之,那几年我也算是投身于 DevOps,致力于提升团队研发效率、交付效率与交付质量,但是同时我没有去仔细思考过“什么是 DevOps?”这个问题,我也没有刻意去思考过自己是不是在玩 DevOps。

        去年(2021年)年底,我加入了思码逸,我的 title 第一次从“xxx 云平台研发工程师”变成了“xxx DevOps 工程师”(xxx 表示初级、中级、高级等)。那天我开玩笑说:“以前,我在云原生领域兼职玩 DevOps;以后,我在 DevOps 领域兼职玩云原生”。

好吧,这会我是名正言顺的“xxx DevOps 工程师”了,我总该知道“什么是 DevOps”吧!

三、他们说……

我们先来看一下几家典型的公司是如何定义他们眼中的 DevOps 的,包括:

  • Atlassian(代表产品:Jira、Trello 等)
  • 微软
  • AWS

3.1、Atlassian 回答“什么是 DevOps?”

Atlassion 有一篇题为DevOps的文章,里面有这样一句话:

DevOps is a set of practices, tools, and a cultural philosophy that automate and integrate the processes between software development and IT teams. It emphasizes team empowerment, cross-team communication and collaboration, and technology automation.

我尝试翻译一下:DevOps 是一系列实践工具和一个融合开发及 IT 团队的文化理念。DevOps 强调赋能团队、跨团队沟通与协作以及技术自动化

可以看到 Atlassian 给的等式是:

DevOps = 工具 + 实践 + 文化

Atlassian 还提到一个 DevOps 团队包含了开发和 IT 运维,大家一起协作,共同参与产品的整个生命周期,一起为提升软件质量和加速软件开发过程而努力。DevOps 模式下开发和运维不再是独立的“筒仓”,而是几乎被整合成一个团队,这个团队的工程师技术栈会覆盖开发、测试、运维等。同时 DevOps 团队会利用一系列的 DevOps 工具链来实现诸如持续集成、持续发布、流程自动化、高效协作等等目的。

Atlassion 给的“无穷环”长这样:

 

用“无穷环”表示 DevOps 生命周期,是因为 DevOps 的根本理念是“持续”,也就是“没有终点”。Atlassion 将整个 DevOps 生命周期分成6个阶段,分别是:

  • 计划(Plan)
  • 构建(Build)
  • 持续集成和部署(或者交付)(Continuous Integration and Deployment or Delivery)
  • 监控和告警(Monitor and Alert)
  • 运维(Operate)
  • 持续反馈(Continuous Feedback)

另外从这个环里我们还能看到 Atlassian 想强调沟通与协作是贯穿 DevOps 生命周期全过程的

3.2、微软回答“什么是 DevOps?”

微软这篇 Introduce the foundation pillars of DevOps: Culture and Lean Product 我特别喜欢!这个标题的意思是“介绍 DevOps 的基柱:文化和精益产品”。

文章第一句话:

DevOps is the union of people, process, and products to enable continuous delivery of value to our end users.

DevOps 是人、过程和产品的结合,使能持续地向终端用户交付价值

微软还提到:

Typically, the goal for Development is to deliver more features faster, and the goal of Operations is to achieve better system stability. DevOps aligns these disciplines by using a framework of best practices proven to increase speed to market while improving system stability.

多数情况下,开发的目标是快速发布更多的新特性,而运维的目标是保证更高的系统可用性。DevOps 通过切实可行的最佳实践体系来拉齐这两个目标,在提升系统稳定性的同时加速产品交付到市场的速度。

这里微软可以看到微软给的第一个等式:

DevOps = 人 + 过程 + 产品

然后微软从“人 + 过程 + 产品”进一步提炼了 DevOps 的4大基柱:文化、精益产品、架构和技术

也就是:人 + 过程 + 产品 -> 文化、精益产品、架构 + 技术

微软给的“无穷环”长这样:

 

图里描绘的 DevOps 生命周期还是分成6个阶段,分别是:

  • 计划(Plan)
  • 构建(Build)
  • 持续集成(Continuous Integration)
  • 部署(Deploy)
  • 运维(Operate)
  • 持续反馈(Continuous Feedback)

外加贯穿整个 DevOps 生命周期全过程的“协作(Collaboration)”。

在图外,微软还定义了对其而言 DevOps 的8大能力:

  • 持续计划(Continuous Planning)
  • 持续集成(Continuous Integration)
  • 持续发布(Continuous Delivery)
  • 持续运维(Continuous Operations)
  • 持续质量(Continuous Quality)
  • 持续安全(Continuous Security)
  • 持续协作(Continuous Collaboration)
  • 持续改进(Continuous Improvement)

每次看到这里我总觉得微软的图该更新一版

另外微软有一句特别有深度总结:

What is new? Continuous Everything. The process is a journey and requires a growth mindset to continually evolve and improve.

“Continuous Everything”,铿锵有力!微软强调 DevOps 过程是一段没有终点的旅途,要求我们抱着成长的观念模式,持续地改进,永不满足。

3.3、AWS 回答“什么是 DevOps?”

不难猜到,AWS 也有一篇文章来回答“What is DevOps?”

DevOps is the combination of cultural philosophies, practices, and tools that increases an organization’s ability to deliver applications and services at high velocity.

DevOps 是文化理念、实践和工具等的组合,能够提升一个组织快速交付应用和服务的能力

这里 AWS 给了一个等式:

DevOps = 文化 + 实践 + 工具

不过这篇文章里 AWS 不落俗套,没有画一个自己的“无穷环”,而是给了这样一张图:

 

 

这里提到了:

  • 构建(Build)
  • 测试(Test)
  • 发布(Release)
  • 监控(Monitor)
  • 计划(Plan)

还可以看到这个“交付管道”和“反馈环”连接的是“企业”和“客户”,可见 AWS 希望强调“DevOps 的目的是更快地向客户交付”。

四、DevOps 文化

我曾一度片面以为 DevOps 要解决的问题就只是工具问题,也就是如何选择或者开发好用的 DevOps 工具 or 平台,从而提升企业内部整个研发生命周期的运行效率。不记得是哪一天,我突然有一个强烈的想法:工具只是工具而已,文化建设才是成败的关键!

文化决定了我们如何去做事,工具决定了,决定了啥?可能啥也决定不了。因为我认为工具也是被文化所决定的。

4.1、什么是文化?

简单说,文化就是一个组织的社交遗产,也就是一个组织对于其成员的各种行为的响应模式。

比如当我们说一个企业有“加班文化”时,其实是在说在这个企业内,员工加班会得到奖赏,而不加班会受到惩罚。或者我们说一个企业是“狼性文化”、“奋斗者文化”…… 不同的文化背后对应的也就是这个企业对于员工不同行为的不同响应模式。

一个企业的文化决定了在这个企业内:

  1. 什么事情是对的,什么事情是错的;
  2. 什么事情是重要的,什么事情是不重要的;
  3. 什么事情是值得做的,什么事情是不值得做的。

所以文化决定了一个企业会去招聘哪些人,会开除哪些人,会提拔哪些人

看到这里可能你已经在思考自己呆过的企业对员工有哪些要求,在鼓励什么,在惩罚什么…… 没错,此刻在你脑海中闪现的一幕幕就是企业文化。

4.2、什么是 DevOps 文化?

这幅图大家肯定都不陌生:

 

什么是 DevOps 文化?

其实从这幅图中我们就能看到文化的影子。我们都知道 DevOps 强调打通开发团队与运维团队的壁垒,要求两个团队拉齐认知与责任,不再各自为战,而是一起为更快地交付更高质量的产品而努力。没错,这就是最基础的 DevOps 文化。

那么如何拉齐认知与责任呢?

首先可以确认的是,我们在组织架构上直接融合 Dev 和 Ops 团队,这并不是一个 DevOps 团队。人是不是坐在一起,改变的只是沟通的效率。这里我想强调两点:

  1. 责任共担,在一个 DevOps 模式组建团队里,每个人都需要为软件开发交付的整个生命周期而负责;
  2. 技能共享,通过持续学习,互相学习,让本是传统 Dev 的工程师学习 Ops 的技能,同时传统 Ops 的工程师也需要学习 Dev 的技能。

Dev 与 Ops 互相学习彼此领域技能,每个人都懂开发又懂运维,抱着“成长的观念”,持续学习,不满足于当前已掌握的技术栈。

但是我们也需要意识到不能要求每个工程师都精通开发与运维,这是不可能的。这里说的 Dev 掌握 Ops 能力,更多的是 Dev 能够借助完善的工具链从而掌握“应用运维”的能力,能够在自己完成开发之后,有能力和权限将应用部署上线,同时线上应用出问题后,能够直接对其负责,定位、修复、更新升级等。而一些基础设施的运维能力需要独立出来考虑,比如机房里的局域网配置、虚拟机挂 NAS 盘等传统运维能力。

同理 Ops 需要理解应用开发的生命周期,知道 Dev 的痛点,尤其是在流程上的痛点,比如怎样提升应用的构建速度,怎样优化应用的 cd 流程等,Ops 要关注应用的“生产过程”,进而发力去优化这个过程或相应的工具,让应用能够更可靠更快速地完成 cicd 流程等,更容易地部署上线或者对外交付。也就是说我们并不是要求 Ops 也去写业务代码,而是协助 Dev 去解决业务代码之外的痛点,让 Dev 能够更加专注于业务功能实现。

最后,一个 DevOps 模式组件的团队中每个人都为整个软件研发生命周期的速度和质量负责,每个具体的角色就像一个大头钉,底部很宽,代表着技术面广,关注整个软件研发生命周期的所有环节;同时顶部很高,在某个环节里专注,做好做精。

DevOps 成功落地的关键是什么?

我们前面说到的“其乐融融”的场景,我们希望 Dev 和 Ops 能够互相学习,共担责任,一起为更快更好地交付产品而努力。但是,工程师们为什么要这样做?他们的动力在哪里?

4.3、领导与激励

Gartner 曾出过一个分析报告,表明在2023年,90%的 DevOps 改革将会失败(相较于预期)。而失败的主要原因是领导层管理方法的局限。

其实这是显而易见的,DevOps 可以称为一种“改革”,而很多人是抵触“变化”,抵触“新事物”的。比如 DevOps 鼓励接受失败,快速失败,从失败中学习经验,进而在更长的时间维度上争取更大的成功。但是可能你遇到的刚好是一个“失败惩罚型”领导,那么你的团队就会惧怕失败,从而放弃创造与尝试新技术,选择安于现状。

一个技术团队的领导首先自己需要懂技术,有丰富的经验,这是基础要求。但是除此之外,更重要的是团队领导能够激励整个团队,去发挥整个团队的主观能动性,让所有团队成员都能够有动力持续学习,快速学习,同时也能够敢于失败,快速失败且不惧怕失败,把失败当做一个学习的机会,进而不断成长,让整个团队的战斗力能够越来越强。

所以领导怎样激励工程师呢?

福利?比如一些大厂提供的免费零食或者定期的下午茶?免费的咖啡或者午餐?

没错,作为一个工程师,这一切的福利都会让其开心,但是其实无法激励其更加认真努力地工作。工程师的薪资水平普遍不低,所有这些零食也好,咖啡也好,大概率不会到其月薪的零头。同理,工程师找工作时,看重的也绝不会是一个企业是否提供免费午餐和下午茶。

那么工程师看重的是什么?

在选择一家企业的时候,可能工程师第一个考虑的是薪资,剩下的可能是成长的空间、工作内容是否感兴趣等等等等。但是进入一家公司以后,真正开始工作的时候,工程师看重的是什么?我认为可能是:

  • 精通
  • 自驱
  • 目标

我们逐个来解释一下。

1. 精通

我们在某个工作方向做的好,我们擅长某个技术方向,进而很好地完成相应的工作,这时候我们会有一种成就感,满足感,我们会觉得自己得心应手,同时大概率会获得认可,赞扬,因此接下来的时间里我们就更加愿意在这个方向上继续努力,做的更好。也就是说一个工程师能够有机会专注于自己精通的技术上发力,那么他大概率会感受到激励。

反例是什么呢?比如你是一个 Java 工程师,但是你的领导擅长 PHP,并且觉得 PHP 是世界上最好的语言,于是要求整个团队转向使用 PHP,这时候你会放弃自己研究多年的 Java 技术栈,努力学习 PHP 并决心干出一番成绩吗?

2. 自驱

我们希望组建一个学习型、创造型的团队,每个人能够持续成长,乐于创新,自我驱动。这就需要领导能够允许团队花时间去学习,去输入,而不是一味地输出,每时每刻汇报自己写了几行代码。同时这也要求领导自身勇于接受新事物,拥抱变化,而不是“不求有功,但求无过”。举个例子:假如你的领导最担心的是线上应用出事故,并且他认为稳定的第一要素就是不要引入新技术,新工具,那么这时候你的领导也不会在意你是不是有时间学习,也不会允许你花时间去研究新技术,因为这一切只会带来不稳定。如果领导害怕失控,因而拒绝创新,那么这样的团队成员也就只能满足于实现日复一日的常规需求开发迭代,而不会享受技术,自我驱动,拥抱创新。

3. 目标

显而易见,团队每个成员都需要知道自己为什么做?目的是什么?目标是什么?而不是领导心里藏着一个目标,然后简单地指挥团队成员完成一件件具体的零散的工作项。如果团队成员只知道今天需要完成事务A,明天需要完成事务B,而不知道为什么要做,最终要做成什么样,那么大家只会满足于机械地完成任务,而不会有动力追求“如何做得更好”。

五、总结

所以 DevOps 是什么?

我尝试给出我的答案:

DevOps 是一种文化理念、工具与实践的结合,目的是更快更可靠地向用户持续交付价值。其中最重要的是文化,文化要求 Dev 和 Ops 团队责任共担,目标一致,也要求整个团队持续学习,抱着成长的心态,Continuously Everything。其次 DevOps 离不开高效的工具集,工具是自动化的基础。最后我们要在各个环节追求最佳实践,不管是工具的使用,还是团队的协作模式,沟通方法上面。

最后,关于标题“什么是DevOps?看这一篇就够了!”,我想告诉你,DevOps 文化里不存在“够了”,所以我不得不承认,我撒谎了。本文只代表我个人现阶段的粗浅认知,我建议你查阅更多的资料,持续学习,永不满足。当然如果本文对你有一点点的帮助,那么我很满足。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/766607.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

谈人工智能和数据治理

一、说明 生成式人工智能已经开始撼动数据治理的世界,并且将继续这样做。 自 ChatGPT 发布以来才 6 个月,但感觉我们已经需要回顾了。在这篇文章中,我将探讨生成式人工智能如何影响数据治理,以及它在不久的将来可能会把我们带到哪…

APP打包教程(使用HBuilder X工具打包uni-app)

App打包(使用Hbuilder进行App打包) 一、修改接口地址 1.打开uni-app下config/app.js修改接口地址,将下图红框中的地址修改成您的域名 二、配置参数 1.打开 uni-app 根目录下的 manifest.json 文件, 点击《基础配置》&#xff0…

户外运动耳机怎么选?这几款耳机最适合在运动时佩戴!

随着人们开始追求运动和健身带来的乐趣,以及在运动过程中享受音乐的过程,耳机逐渐成为当下的刚需,其中骨传导耳机凭借防水防汗、佩戴稳固不掉落加上开放式聆听受到当下消费者的热烈欢迎,有优点就有缺点,由于骨传导耳机…

opengauss 在一个机器上搭建主备集群

项目上需要高斯主备集群,试了好几个版本。最后搭建出一个在一个机器上的主备。用做测试,记录一下。 下载安装包 从openGauss开源社区下载对应平台的安装包。 a. 通过软件包 | openGauss登录openGauss开源社区,选择3.1.0版本对应平台极简版安…

【网络可用性】

网络可用性 Availability defined in a service-level agreement (SLA) between a network operator (carrier) and a customer. 关于SLA,可参考 思科Service Level Management: Best Practices White Paper 可用性对应的停机时间 转载于 https://blog.csdn.net/a…

Spark(27):Spark任务调度机制

目录 0. 相关文章链接 1. Spark任务调度概述 2. Spark Stage级调度 3. Spark Task级调度 3.1. 调度策略 3.1.1. FIFO调度策略 3.1.2. FAIR调度策略 3.2. 本地化调度 3.3. 失败重试与黑名单机制 0. 相关文章链接 Spark文章汇总 1. Spark任务调度概述 在生产环境下&am…

C#为什么不能成为大学编程入门的首选?

大学编程入门不以C#作为首选的原因有多个因素。虽然C#是一种功能强大的编程语言,但在大学编程入门阶段,通常会选择其他语言作为首选,以下是一些可能的原因: 我这里刚好有嵌入式、单片机、plc的资料需要可以私我或在评论区扣个6 …

投个 3D 冰壶,上班玩一玩 | 物理引擎

本篇文章将介绍如何使用物理引擎和图扑 3D 可视化技术来呈现冰壶运动的模拟。 Oimo.js 物理引擎 Oimo.js 是一个轻量级的物理引擎,它使用 JavaScript 语言编写,并且基于 OimoPhysics 引擎进行了改进和优化。Oimo.js 核心库只有 150K ,专门用…

抢滩“返校季”!这些品类拉开爆单之旅!

“返校季”作为仅次于“黑五网一”的购物旺季。在开学的前四到六周,家长与学生就会开始陆续采购返校季所需的物品,从七月下旬一直持续到九月,都将是“返校季”的购物高峰。今年的“返校季”又将呈现什么样的消费趋势?消费者的消费…

Julia变量作用域问题

变量作用域问题 1.软作用域与硬作用域 1.1软作用域 软作用域是指在代码块内部定义的变量,如果外部有同名变量,则内部变量会被优先使用,即“遮蔽”外部的同名变量,而不影响外部变量。 1.2硬作用域 硬作用域是指在代码块内部定…

DataGrip使用随笔

由于公司不让使用NAVIcat,顾用datagrip作为替代软件 1.下载和安装 从官网下载安装包https://download.jetbrains.com.cn/datagrip/datagrip-2023.1.2.exe后,选择安装位置并试用 2.链接数据库 需要先新建个项目存储所有的db连接信息,然后选…

安卓通过adb pull和adb push 手机与电脑之间传输文件

1.可以参考这篇文章 https://www.cnblogs.com/hhddcpp/p/4247923.html2.根据上面的文章,我做了如下修改 //设置/system为可读写: adb remount //复制手机中的文件到电脑中。需要在电脑中新建一个文件夹,我新建的文件夹为ce文件夹 adb pull …

2.9Frame 框架

2.9Frame 框架 这一次的效果将会像下面的图片一样. Frame 部件 Frame 是一个在 Windows 上分离小区域的部件, 它能将 Windows 分成不同的区,然后存放不同的其他部件. 同时一个 Frame 上也能再分成两个 Frame, Frame 可以认为是一种容器. ###定义一个label显示on the windo…

视频问答新增或修改视频问答

通过问答id新增或修改视频问答题目 新增或修改视频问答 图3:视频问答功能(观看效果) 图4:视频问答功能(观看效果) 图5:视频问答功能(观看效果) 单元测试 Testpublic voi…

Linux下九个实用脚本

目录 1.批量创建用户并设置密码脚本 2.查看网卡实时流量脚本 3.nginx访问日志脚本 4.dos防范攻击(自动屏蔽攻击脚本) 5.监控多台服务器磁盘利用率脚本 6.监控MySQL主从同步异常脚本 7.批量检查网站异常脚本 8.查看服务器资源利用率脚本 9.查找占…

高效出报表的工具有哪些?奥威BI报表工具怎样?

随着企业精细化数据分析的展开,数据分析报表的制作压力也随之增加。对企业而言,拥有一个高效出报表的工具十分重要。高效出报表的工具有哪些?奥威BI报表工具的效率够不够高? 高效出报表的工具有很多,奥威BI报表工具就…

java多线程之并发容器集合

一、多线程操作容器存在的问题 如下代码 public class NotSafeDemo {public static void main(String[] args) {List list new ArrayList();for (int i 0; i < 100; i) {new Thread(() -> {list.add(UUID.randomUUID().toString());System.out.println(list);}, &quo…

Vue导入Echarts实现散点图 axios解析excel流数据 echarts数据可视化前端展示

为实现从本地服务器下载xlsx文件至前端vue echarts中展示&#xff0c;踩过许多坑&#xff0c;现将完整流程和源码分享。 1、 vue axios get请求 返回304 Not Modified 不更新数据 原因&#xff1a;由于浏览器缓存了get请求&#xff0c;导致不管如何刷新&#xff0c;数据都不更…

Echarts:柱状图的第一个柱子超出了y轴

问题 使用Echarts绘制柱状图的时候&#xff0c;第一个柱子超出了y轴&#xff1a; 解决 boundaryGap 此属性与坐标轴两端空白有关。默认值为true即留空&#xff0c;false则表示柱子顶头,而出现上述现象,是因为代码中参数 boundaryGap设置为了false 将boundaryGap的值改为tru…

sadtalker-- 本地生成数字人

文章目录 概要工具讲解安装流程1. 安装Python2. 安装FFmpeg3. 安装Sadtalker4. 导入模型 使用流程1. 生成语音2. 上传图片跟语音3. 点击生成&#xff0c;漫长等待4. 虚拟内存 小结 概要 sadtalker&#xff0c;可以根据图片以及语音&#xff0c;生成动态视频&#xff0c;跟现在…