【k8s】:DevOps 模式详解

1.什么是DevOps模式?

DevOps 是当下非常火爆的一个概念,受到了很多互联网巨头的推崇。那么什么是 DevOps?它的全称是:集成开发与运维。至于它到底是干什么用的,为什么现在这么火爆,还得从源头说起。

1.1 瀑布模型

一个软件从零开始到最终交付,大概会经历规划、编码、构建、测试、发布、部署、维护等几个阶段:

最初,程序比较简单,工作量也不大,程序员一个人就能完成各阶段的工作。

随着软件行业的不断发展,软件的规模也逐渐庞大,软件的复杂度不断提升,一个人已经无法应付自如,因此开始出现精细化的分工。

程序员的数量扩大,工种增多,除了软件开发工程师,还有软件测试工程师、软件运维工程师等等。

软件开发人员花费数周甚至数月的时间编写代码,然后将代码交给 QA(质量保证)团队进行测试,然后将最终版本交给运营团队进行部署。全部三个阶段:开发、测试、部署。

早期采用的软件交付模型称为"瀑布模型":

简而言之,瀑布模型意味着等待一个阶段的所有工作完成后再进入下一个阶段。

这种模式适合条件比较理想的项目(用户需求非常明确,开发时间非常充足),大家按照流程,轮流做事,各司其职。

1.2 敏捷开发

但是项目不可能是单向运作的,客户也有需求,产品也有问题,需要改进,随着时间的推移,用户对系统的要求不断提高,而与此同时,用户给出的时间周期却越来越短,在这种情况下,大家发现繁琐、缓慢的瀑布式开发已经不再合适。

因此,软件开发团队引入了一个新概念,即著名的"敏捷开发"。

敏捷开发在 2000 年左右开始受到关注,是一种能够应对快速变化需求的软件开发能力。简单来说就是把大项目变成小项目,把大时间点变成小时间点,然后:

与 DevOps 经常出现的两个词是 CI 和 CD。CI 代表持续集成 (Continuous Integration),而 CD 则对应多个英文单词,持续交付 (Continuous Delivery) 或持续部署 (Continuous Deployment)。

说是"连续",其实就是"加速-重复-加速-重复......",就像这样。画个图大家可能更明白:

敏捷开发大大提高了开发团队的工作效率,版本更新更加快捷。

很多人可能会想:更新速度快的话,风险不是更大吗?

事实上,事实并非如此。

敏捷开发可以帮助更快地发现问题,更快地将产品交付给用户,更快地得到用户的反馈,因此团队可以更快地做出响应。而且 DevOps 小步子、快跑带来的版本变更相对较少,风险也较小(如下图所示),即使出现问题,也会相对容易修复。

1.3 DevOps开发与运营一体化

敏捷开发虽然大大提高了软件开发的效率和版本更新的速度,但是其效果却仅限于开发阶段,研发人员发现运维端依然是一块坚实的阻碍,成为了新的瓶颈。

运维工程师和开发工程师的思维逻辑完全不一样,运维团队的座右铭很简单,就是"稳定压倒一切",运维最核心的诉求就是避免出现问题。

什么时候最容易出现问题?当发生变化的时候,最容易出现问题。所以运维是非常排斥"变化"的。

于是,两人的矛盾就爆发了:

这时候,DevOps出现了。DevOps这个词,其实是Development和Operations两个词的组合,它的英文发音是/de'vɒps/,类似"迪沃普斯"。

DevOps 是一组流程、方法和系统,旨在促进开发、技术运营和质量保证 (QA) 部门之间的沟通、协作和集成:

从目标上来看,DevOps就是为了让开发人员和运维人员能够更好地沟通和协作,并通过自动化的流程让整体软件流程更加快捷、可靠。

很多人可能觉得,所谓的 DevOps,无非就是 Dev+Ops,只要把两个团队合并起来,或者把运维划归到开发,就可以了,简单粗暴。

注意,这种观点是错误的,这也是近年来DevOps难以落地的主要原因。

想要真正把 DevOps 做到极致,首先要做的就是转变思维方式,或者说"洗脑"。不但运维人员需要洗脑,开发人员也需要洗脑,员工需要洗脑,领导更需要洗脑。

DevOps 不只是组织架构的改变,更是企业文化和思维模式的改变,如果思维模式不能改变,就算员工拼凑在一起,也不会擦出火花。

除了洗脑之外,整个流程的规范和标准都按照DevOps的思维进行重新梳理。

在DevOps流程下,运维人员会在项目开发期间介入开发过程,了解开发人员所使用的系统架构和技术路线,制定合适的运维计划。开发人员也会在运维前期参与系统部署,并为系统部署提供优化建议。

DevOps的推行促进了开发和运维人员之间的沟通,增进了相互的了解。

在转变思维和流程的同时,如果要全面推行DevOps,当然离不开软件和平台的支持。

支持 DevOps 的软件有很多,篇幅有限就不一一介绍了,不过现在 DevOps 这么火也是因为这些软件和平台,你可以趁机卖掉赚钱。

在上述关键因素中,技术(工具与平台)最容易落地,其次是流程,而思维方式的转变最难。

也就是说,DevOps考验的不只是一家公司的技术,更考验公司的管理水平和企业文化。

对比上面提到的瀑布式开发与敏捷开发,我们可以明显的看到,DevOps贯穿了整个软件生命周期,并不局限于开发阶段。

云计算技术近几年发展很快,虚拟化、容器、微服务等概念大家应该都很熟悉,提到这些概念的时候我们偶尔也会提到DevOps。

它们之间有什么联系?

事实上非常简单。

你可以想象一下,如果我们要将一项任务划分成更小的部分,是加工一大块铁更方便,还是把它分割成几块进行加工更方便?

显然拆分之后会更加方便。

所谓"微服务",就是将原本黑箱化的整体产品从提供多个服务的整体拆分(解耦)成多个提供不同服务的个体。如下图所示:

在微服务架构下,不同的工程师可以处理他们负责的模块,例如开发,测试,部署和迭代。

虚拟化其实是一种敏捷的云计算服务,它从硬件角度把一个系统"划分"成多个系统,使系统之间相互隔离,便于微服务化。

容器则更加彻底,不再划分到不同的操作系统,而是划分到操作系统上的不同"运行环境"(Container),占用资源更少,部署速度更快。

虚拟化和容器其实为DevOps提供了很好的前提条件,开发环境和部署环境可以得到更好的隔离,减少互相的影响。

这也是为什么DevOps在2009年并不流行,而现在却越来越流行的主要原因之一。

相关推荐
wanhengidc30 分钟前
网站服务器中的文件被自动删除的原因
运维·服务器
9毫米的幻想1 小时前
【Linux系统】—— 编译器 gcc/g++ 的使用
linux·运维·服务器·c语言·c++
helloliyh1 小时前
Windows和Linux系统安装东方通
linux·运维·windows
LilySesy2 小时前
【业务案例】F.13——SAP系统标准的清帐程序有BUG?
运维·bug·sap·abap·esb·internet服务
张某人想退休2 小时前
自动化实现的思路变化
运维·自动化
van叶~3 小时前
Linux探秘坊-------4.进度条小程序
linux·运维·小程序
代码讲故事7 小时前
从Windows通过XRDP远程访问和控制银河麒麟ukey v10服务器,以及多次连接后黑屏的问题
linux·运维·服务器·windows·远程连接·远程桌面·xrdp
IT北辰9 小时前
Linux下 date时间应该与系统的 RTC(硬件时钟)同步
linux·运维·实时音视频
Shootingmemory10 小时前
自动化01
运维·自动化
苹果醋310 小时前
golang 编程规范 - Effective Go 中文
java·运维·spring boot·mysql·nginx