从 DevOps 到平台工程:软件开发的新范式
DevOps 是一种将开发和运营结合起来的方法,在应用规划、开发、交付和运营方面将人员、流程和技术结合起来。DevOps 使以前孤立的角色(如开发、IT运营、质量工程和安全)之间进行协调和合作。一直以来,DevOps 的采用都是以帮助企业更快地向客户提供价值,更好地适应市场和竞争,并保持系统的稳定性和可靠性为目标。
然而,近两年关于“DevOps 已死”的讨论越来越多。该观点持有者认为 DevOps 模糊性,实施起来的复杂性及高成本等问题,未能达到帮助企业实现其加快交付、提高质量和降低成本的目标。
在这篇文章中,我们将理性分析一些反对 DevOps 的常见论点,并一同探讨在当下 DevOps 实施时所面临的挑战,以及 DevOps 未来演变与平台工程的关联。
反对 DevOps 的三大观点
DevOps 的定义过于模糊
关于 DevOps 的批评之一是它过于模糊,缺乏一个明确的定义。DevOps 对不同企业和团队来说意味着不同的东西,而且对 DevOps 的实际内容也没有达成共识。甚至有言论表示 DevOps 只是一个被供应商和行业顾问过度使用的流行词。
DevOps 实际上并不是一套僵硬的框架或规则,而更是一种文化和思维方式,能够适应不同的环境和目标。DevOps 并没有规定团队应该如何工作,而是提供了可以帮助团队更好地合作的原则和实践;也没有规定团队应该使用什么工具,而是鼓励团队使用最适合他们需要的工具。因此 DevOps 的模糊性我们可以视为它的灵活性。DevOps 允许团队根据他们的具体挑战和机会来定制他们的方法,还允许团队进行试验并从经验中学习。
DevOps 给企业造成成本负担
反对 DevOps 的另一主要观点就是,DevOps 的实施和维护成本过高。由于 DevOps 需要对企业的文化、组织架构和技术进行大幅度的改变,同时,还需要企业在时间、成本以及基础设施方面进行大量投资。因此有部分企业中的 IT 主管或领导并不愿意在此花费过多,因为他们无法保证 DevOps 实施后的实际效果。
不可否认,企业实施 DevOps 的确是个不小的工程。但客观来说,DevOps 并不一定是一个全有或全无的主张。企业可以逐步和有选择地采用 DevOps,根据自身需求和商业目标来选择合适的工具和实施方式,企业中现有的资源和基础设施也可以被利用起来。这样企业可以将采用 DevOps 的前期成本和风险降到最低。
关于实施效果,DevOps 并不是一套即时的解决方案,需要从长期利益来看。DevOps 可以帮助企业减少交付过程中的浪费、错误、延迟和失败,同时提高软件交付的质量、效率、团队间的协作以及客户满意度。从长远来看,这些成果可以转化为更低的成本、更高的收入和更好的竞争优势。
DevOps 过于复杂
第三个反对 DevOps 的声音来自于对其复杂程度的质疑,认为 DevOps 难以实施和管理。DevOps 通常涉及多项技术挑战和较高的复杂性,因此导致开发团队和运营团队难以上手。同时还涉及跨多个团队的大量协调和沟通,这在大型或分布式组织中可能是个极大的挑战。
实际上 DevOps 是为了简化和精简软件开发生命周期,而不是使其复杂化。DevOps 依赖自动化、标准化和集成,以减少人工任务、错误和依赖性。此外,DevOps 并不是一个适用于所有情况的万能解决方案。企业需要根据他们的具体环境和要求来定制 DevOps 方法,并利用各种工具和技术来促进 DevOps 的实施和管理。例如,使用版本控制来跟踪和记录变化;或使用告警管理来统一和优先处理紧急状况。
DevOps 实际存在的问题
DevOps 自 2007 年随着企业规模、行业以及现有的 IT 环境的变化,针对 DevOps 的反对声音也并非空穴来风,DevOps 在概念上、流程和技术等方的确面临着巨大的挑战。
首先许多企业对 DevOps 的概念存在误解,未能采用 DevOps 的基本原则和文化,导致实施时存在偏差,即仅仅雇佣一个“DevOps 工程师”或使用一些 DevOps 友好的工具。这就导致了混乱、孤岛和低效率等问题。因为 DevOps 并不是一个角色或一个工具,而是一种思维方式和一种实践,需要企业变革和确保一致性。
DevOps 的核心理念是“you build it, you run it”,这给开发人员增加了过多的压力和认知负担,开发人员不得不处理复杂且多样的基础设施、安全、合规和运维等问题,开发人员通常不擅长或缺乏处理这些任务的技能和工具,从而需要耗费大量时间和精力。而过多的精力花费在非开发任务上,导致开发人员无法将核心能力价值最大化利用。
此外,随着分布式系统的广泛应用,其复杂性越来越高,DevOps 变得更加难以实施和管理(当然问题的根本来自于现代软件开发的复杂性增加而非 DevOps 本身)。企业需要对其基础设施和环境有更多的控制和可见性,以及更多的敏捷性和速度来满足业务需求。DevOps 也难以应对云原生技术(如容器、Kubernetes、微服务和无服务器)的多样性和波动性。
平台工程的崛起
为了解决上述问题,一些企业正在尝试将 DevOps 演变到下一阶段,通过创建可重用、自助式平台的实践,使开发人员能够以最小的摩擦构建、部署和运行其应用程序,这就是平台工程逐渐崛起的契机。
平台工程相比 DevOps 有以下几个优势:
赋能开发人员:平台工程为开发人员提供了一个“黄金路径”,为他们的应用程序提供最佳的工具、实践和安全措施。开发人员可以自助获取他们需要的资源,而不用担心底层的细节或依赖关系。平台工程还通过降低复杂性、提高生产力、增强质量和加速反馈循环,改善了开发人员的体验。
启用平台工程团队:平台工程拥有专门的平台工程师团队,负责构建、维护和改进支持开发人员的平台,平台工程师充当促进者和协调者。同时,平台工程师可以利用云原生技术(如容器、Kubernetes、微服务和无服务器)创建可扩展、弹性、可移植和成本效益良好的平台。
利用平台编排:平台工程使用平台编排工具,自动化跨不同环境的平台的配置、部署和管理。平台编排工具还提供对平台及其使用情况的可见性、监控和治理。平台编排工具帮助平台工程师为开发人员提供一致、可靠和安全的平台。
改善业务成果:平台工程通过实现更快更好的软件交付,帮助组织实现其业务目标。平台工程能够培养开发人员和平台工程师之间的协作、创新和学习文化,并帮助组织以可靠、高成本效益和安全的方式进行扩展。
结论
DevOps 并没有死,而是在革新和进化,平台工程则是 DevOps 的下一个演变阶段,相较于 DevOps,其优势是以可持续的方式赋能和助力开发人员。平台工程能够帮助企业组织应对云原生环境的复杂性和增长,同时实现更快更好的软件交付。
从 DevOps 到平台工程:软件开发的新范式的更多相关文章
- AgileEAS.NET SOA中间件平台/敏捷软件开发平台 and SQL详解
AgileEAS.NET SOA中间件平台/敏捷软件开发平台 http://www.smarteas.net/ SQL详解: http://www.w3school.com.cn/sql/func_d ...
- AgileEAS.NET SOA中间件平台/敏捷软件开发平台
AgileEAS.NET SOA中间件平台/敏捷软件开发平台 最新下载 一.前言 AgileEAS.NET SOA中间件平台,简称EAS.NET,是基于敏捷并行开发思想和Microsoft .Net构 ...
- DevOps、SRE、平台工程的区别
DevOps.SRE和平台工程的概念在不同时期出现,并由不同的个人和组织开发. DevOps作为一个概念是由Patrick Debois和Andrew Shafer在2009年的敏捷会议上提出的.他们 ...
- 编程学习笔记(第三篇)面向对象技术高级课程:绪论-软件开发方法的演化与最新趋势(3)软件开发的现状、UML扩展
一.软件开发的现状 软件领域正在发生一个巨变,特别是近几年来,软件领域正在发生翻天覆地的变化. 这一变化主要以这个云 + 端大数据, 这些是随着目前最先进的一些技术的产生而产生的. 随着这些新的技术以 ...
- 7 家 IT 厂商 6394.5 万元中标天津公安云项目(虚拟化、数据库、软件开发)
http://mp.weixin.qq.com/s/kjum54HJorGTPtZiM-HE1g 天津市公安局云计算平台项目分为:大数据部分.虚拟化部分.数据库部分,软件开发部分,预算分别为:2350 ...
- 平台+插件软件设计思想及基于COM的原型实现
引言:我们已经习惯于一个人独立进行软件开发,每个人都使用自己的风格进行程序设计,但随着工程项目变大或者是对时间要求比较紧时,就需要几个人,十几个人,甚至是上百个人协作进行软件开发与设计,这时一个比较棘 ...
- 最全 IT 相关网站,软件开发网站收集
前端比较流行的 UI 框架 目前前端用的比较多的框架有如下几个 Ant Design:Ant Design - 一套企业级 UI 设计语言和 React 组件库 Mint UI:https://mi ...
- 从工具、工具箱到数字化软件工厂——DevOps 设计理念与工程实践专场 | CIF 精彩看点
西方经典管理理论认为,组织效率可以归为劳动效率.组织效率和人的效率.美国管理学家泰勒所著的<科学管理原理>被德鲁克誉为"20 世纪最伟大的发明",劳动效率说认为分工提升 ...
- DevOps | 如何快速提升团队软件开发成熟度,快速提升研发效能?
今天一个小伙伴问我,如何「快速提升」一个团队的软件开发成熟度?我犯难了.我个人理解一个团队的软件开发成熟度涉及的东西很多,但最简单最直接的方法就是发钱涨工资,可是估计很多公司不愿意,那就只有扣了. 快 ...
- 研发效能|DevOps 已死平台工程永存带来的焦虑
最近某位大神在推特上发了一个帖子,结果引来了国内众多卖课机构.培训机构的狂欢,开始贩卖焦虑,其实「平台工程」也不是什么特别高深莫测的东西.闲得无聊,把这位大神的几个帖子薅了下来,你看过之后就会觉得没啥 ...
随机推荐
- 《深入理解高并发编程:JDK核心技术》-冰河新书上市
大家好,我是冰河~~ 废话说多了没用,并发编程技术一直是初级程序员进阶高级工程师的前提条件,也是成为大厂程序员的必备技能,更是突破自身技术瓶颈的必经之路. 2022年6月我出版了"冰河技术丛 ...
- JAVA数据类型以及什么是字节
强类型语言:要求变量的使用要严格符合规定,所有变量都必须先定义才能使用(安全性高) java的数据类型分为两大类 基本类型(primitive type) 引用类型(reference type) / ...
- redis.clients.jedis.exceptions.JedisConnectionException: Failed connecting to "xxxxx"
Java 连接 Redis所遇问题 1. 检查Linux是否关闭防火墙,或对外开放redis默认端口6379 关闭防火墙. systemctl stop firewalld 对外开放端口.firewa ...
- SpringBoot 项目使用 Sa-Token 完成登录认证
一.设计思路 对于一些登录之后才能访问的接口(例如:查询我的账号资料),我们通常的做法是增加一层接口校验: 如果校验通过,则:正常返回数据. 如果校验未通过,则:抛出异常,告知其需要先进行登录. 那么 ...
- Flask框架cbv的写法、请求与响应、请求扩展、session源码分析、闪现
本篇文章将会详细讲在flask框架如何写cbv.请求与响应.请求扩展.session源码分析.闪现等知识点. 目录 一.flask写CBV 二.请求与响应 三.session 四.闪现flash 五. ...
- 「刷起来」Go必看的进阶面试题详解
勤学如春起之苗,不见其增日有所长:辍学如磨刀之石,不见其损日有所亏. 本文的重点:逃逸分析.延迟语句.散列表.通道.接口. 1.逃逸分析 逃逸分析是Go语言中的一项重要优化技术,可以帮助程序减少内存分 ...
- [Linux]CentOS查看RPM包依赖问题
[经典应用案例] 查看此文前,可先查看 此博文中:在安装软件过程中,如何解决的依赖组件问题? [数据库/Linux]CentOS7安装MySQL Percona版(RPM方式) : 2-1 依赖组件问 ...
- InnoDB引擎之flush脏页
利用 WAL 技术,数据库将随机写转换成了顺序写,大大提升了数据库的性能,由此也带来了内存脏页的问题. 脏页会被后台线程自动 flush,也会由于数据页淘汰而触发 flush,而刷脏页的过程由于会占用 ...
- Kubernetes学习之旅
# Kubernetes学习之旅 ## 引言 - 为什么选择Kubernetes- Kubernetes简介- Kubernetes的发展历程 ## Kubernetes基本概念 - 节点(Node) ...
- 这样也行,在lambda表达式中优雅的处理checked exception
目录 简介 lambda表达式中的checked exception lambda中的unchecked exception 对lambda的最终改造 总结 简介 最近发现很多小伙伴还不知道如何在la ...