运维工程师要失业了?抛开噱头与调侃,闲聊我心中的运维!

“在知乎上,我经常受邀请回答很多类似的问题:运维到底是干什么的?运维工作有没有意思?运维有没有前途?运维是不是要被各种技术取代?

然而本人上知乎以休闲娱乐为主,一般不回答正儿八经的技术或者专业相关的问题,这次希望能通过本文向各位描述清楚运维到底是干什么的,至于有没有前途、发展以及会不会失业等,请读者自行判断。

运维是干什么的

「运维」二字可能有几层意思,分别可以指代运维工程师、运维团队或者是整个运维服务体系。

我们可以看出,这三层是从狭义到广义的递进。相信绝大部分人问的都是运维工程师,只有极少数人能意识到还有运维服务体系这一层含义。

我们经常会听到一些言论,比如:

  • 云服务普及了,运维工程师就要失业了。
  • 等 DevOps 或者 SRE 落地了,运维工程师也要失业了。
  • 容器技术普及了,运维工程师也该失业了……

也记不清运维工程师到底被失业了多少遍,但我认为就算运维工程师被取代了,运维服务也不会消亡,它将伴随并支撑着业务发展的整个生命周期。

为何这样说?我们还是用业务的诞生过程来分析。

一个站点或者 App,大致经历着这样的诞生过程:PM 设计出产品原型,交给 Dev 开发实现、QA 测试,然后交付给 Ops 部署到线上运行,最后供用户使用。

在这几个简单步骤中涉及了众多的人、角色、交付过程等对象,这是一个完整、复杂的系统工程,而任意一个环节的失误都可能影响最终呈现给用户的体验以及效果。

我们重点考虑从 Dev 把业务产品完成后交付给 Ops 到线上运行的这个阶段,Dev 同事主要负责业务产品的功能完整、逻辑正确等业务指标,而 Ops 同事主要负责业务产品的运行质量、稳定性、可用性等系统指标。

无论后面的交付步骤是用 DevOps 还是 SRE 的实现方式,都离不开一个广义的运维服务的执行环节。

所以说, Dev 还是 Dev,Ops 还是 Ops,没有谁被取代,只是运维服务的执行方式升级为更加软件工程化的手段,减少人肉操作,DevOps 强调自动化、拉动式来提高团队交付效率与质量。

而传统的运维需要谋求技术转型,从原来只关注操作系统层面的技术已经不够了,还要增加对程序代码的性能调优、持续交付、容器化等软件基础架构方面的技能提升,也需要持续关注整个业务、应用、服务的生命周期管理。

简单来说,就是把过去传统的黑盒运维的思维方式抛弃,进入白盒运维的时代,我们必须更加深入代码、深入业务运营,让整个线上服务运行于更优质高效的状态。

至于运维是否会被取代,取决于你属于哪种运维。

运维工程师和运维开发工程师

要建设运维自动化或者实践 DevOps 离不开运维开发工程师的参与,但要怎样才能更好地发挥运维开发的作用呢?

我曾作为运维产品经理的角色和各种类型的运维开发一起协作过,团队中有本来就做运维开发的,也有本来做其他业务(电商、平台)的开发转来协助运维团队的。

和他们协作一段日子后,总体感觉如下:

  • 运维开发首先是一个程序员,不是运维工程师。
  • 一个好的运维开发需要具备 「运维理解」+「开发能力」。
  • 对「开发能力」的技术要求低于其他业务形态(如游戏、电商、搜索等)。
  • 对运维业务的理解难度会低于电商、游戏等业务形态,即对「运维理解」的要求不高。
  • 对运维相关技术栈的掌握程度要求高,如 Linux、Git、Nginx、Zabbix、Docker、K8S 等。

综上所述,运维开发是一个深度不算太深的职业分支,而现在之所以对运维开发需求量热起来了,主要由于老一辈的资深运维普遍研发能力有限,而这是有历史原因的。

对于从业 8 年以上的资深运维来说,他们刚开始做运维的时候更多的是接触机房、机架、主机、交换机、防火墙等硬件设备。然后对接业务运维后,一般通过 Shell、Python 等脚本来辅助工作。

等到业界提出 DevOps 的时候,他们往往已经专注于团队管理、容量规划、架构调优、运维服务质量等高级范畴,所以基本不太可能抽出大块的时间来重新学习编码并开发自动化系统。

所以,当我们有自动化系统的建设需求时,需要更专业的程序员来协助。

但一般的非专职运维开发的程序员做出来的系统对于运维来说往往不太好使,这时候有部分年轻的运维工程师升级了研发技能,转型运维开发,把好使的运维系统做出来了,赢得了运维团队的好评,大家都为「运维开发」点赞。

所以,大家将 「好使的运维系统」 和 「运维开发」 等价起来,以为我们只要招来一个运维开发,那么一套完美的运维平台就能自动诞生出来,这是个很大的误区。

其实「好使的运维系统」真正等价于「运维理解」+「开发能力」,这两种能力也是可以分离的,不一定要强加在运维开发工程师一个人的身上。

类似其他业务形态的开发过程,需要产品经理和程序员两种角色分离,企业也不会说要招聘既会写代码、又会出需求的程序员。

所以,当资深运维能把运维自动化的需求细致地文档化下来,把自动化系统的设计、架构等关键环节确立下来,这就是最好的「运维理解」。

这时把这份靠谱、好使、细致的需求文档交给具备强「开发能力」的程序员,最终就可以得到「好使的运维系统」。

当然,资深运维要获取产品经理能力也不是那么简单,而且也需要和运维开发无障碍地探讨技术,个人觉得必须具备且不限于以下技能包:

产品规划、产品设计、面向对象、需求模型、领域模型、设计模型、设计原则、设计模式、产品工具和文档能力等。

所以,当运维需求被理解、分析得足够透彻,以及资深运维获得了「产品经理」能力后,运维开发就是一种普通的开发分支,按需求文档编码即可。

再往高级发展的话,运维开发也可以替代资深运维出需求,升级为运维产品经理,以程序员的思维角度来解决运维服务的工程效率和质量问题,我认为这也是类似 Google 所提倡的 SRE 文化。

最后,很多运维可能考虑要不要转运维开发,当你觉得编码的乐趣远远大于其他运维技能的时候,尽管争取努力去转!

把自己当成一个真正的程序员,以程序员的评价标准来要求自己,不要觉得运维能力和编码能力各自半桶水是好事,正如我前面的那句话:“运维开发首先是一个程序员,不是运维工程师 。”

运维服务体系与技能水平量化

每个运维工程师心中其实都有自己的想法,不妨用思维导图的形式将其列出来,找出自己感兴趣的点,持续深入,打造自己的核心竞争力。

而思维导图也可以继续往横向纵向扩展,形成自己心中完整的一套运维概念。

下面跟大家分享一张思维导图,展示我个人心中的运维服务体系。当然,这里面还有很多可以展开,但细节就不方便透露了,这属于个人经验未必能适用其他运维团队。

由于运维一般讲究广度而忽略了深度,所以容易导致自身的技术栈广而不精的情况,那怎么量化自己的技能水平足够深入呢?

举一个大家都熟悉的 MySQL 技能作为例子,如果把 MySQL 水平定义成 1~10 级,下面是我对各种级别水平的理解。

为何要量化技能呢?因为人的时间、专注力毕竟有限,如何把精力分配到不同的技能上,需要一定的策略。

正常情况下,大家把精力平均分配到各种具体技能,希望可以做到面面俱到,但不会太深入某项技能,所以技能水平达到的级别落在 1~3 之间。

如路人 A 的技能水平表是这样的:(当然还有其他技能项,如网络、安全等等,这里只是简化了方便讨论)。

最低要求

运维是一种需要技能面比较广的工种,大家普遍都是处于技术面广但不深的状态,我把 2 级定义为科普级,意思是达到该级就可以满足各种日常工作要求。

所以说上面的路人 A,最好尽快争取把还在1级水平的 Shell 和 MySQL 都提升到 2 级,就可以满足日常工作要求,这也是我们对运维工程师的最低要求。

进阶要求

除了满足最低要求之外,培养自己的核心竞争力,为日后的发展打下基础,推荐大家对 1~2 项深入学习,达到 4、5 级甚至更高的水平。

随着互联网运维行业的各种 PaaS、IaaS 普及后,自动化程度越来越高,现在已经不像以前那样需要那么多「操作员」。

也就是说,技能水平偏低的运维急需技能升级或者技能转型,能支撑你走多远的不是那些 1、2 级的技能,而是 4、5 级以上的技能。

写在最后

本文是笔者个人对运维以及其职业发展的一些浅薄理解,总的来说,运维还是一个比较有意思且有良好发展的职业分支,虽然偶尔也要背黑锅,但也欢迎更多努力、聪明、有才华的同学加入运维行业。

作者:温峥峰

介绍:百田信息运维技术专家,DevOps Team Leader,超过 8 年互联网运维经验,曾就职于网易游戏,经受过各类海量规模互联网业务模式的历练,专注于运维自动化、DevOps 实践、运维服务体系建设与 SRE 时代下的运维价值挖掘。

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2018-03-28

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏华章科技

你的公司是否真的需要大数据战略?

我们认为,企业应该重视数据统治和数据管理。如果数据是一个企业最重要的资产,然后常规的数据统治项目和数据管理最佳实践是其能够实现的多数投资策略。如果只有其中一种投...

11430
来自专栏PPV课数据科学社区

关于《决战大数据》读这50条就够了

老师在其决战大数据一书中,强调的更多的是一种数据思考方式,书中范例介绍的小偷思维、先开枪后瞄准、CEO关注的三个问题等,都属于数据思考方式重构解决问题的过程。 ...

36940
来自专栏腾讯大讲堂的专栏

浅谈硬件PM与软件PM在产品设计上的差异

导语 | 在鹅厂经历了一个较为完整的智能硬件项目,在项目实践过程中,有一些感悟,准备结合这个产品作为例子做个总结,与大家一起分享下,希望对公司未来做硬件相关的团...

1.1K90
来自专栏个人分享

阿里入职一个月思考(随笔)

  最近没怎么写技术博客了。。原因是,跳到了曾经期望的公司,还在做技术储备。。。如今入职一个月了,已经完全进入状态。同时,也带来更多思考与感悟。

41810
来自专栏张俊红

如何进行运营案例分析(运营新人必学)

关于本篇 本篇为活动运营连载篇,主要有三部分组成:如何策划一?如何分析一场活动?具体案例分析。小红最近在考试而且还在实习,时间有点紧,所以将不定期更新,还请大家...

35870
来自专栏大数据

大数据对移动应用程序开发有哪些影响?

“什么样的应用程序是一个伟大的应用程序呢?”这个问题困扰行业专家多时,大家各执己见一直到现在都还没有定论。 如果要说“一个成功的移动应用程序开发的关键因素是什么...

222100
来自专栏人工智能快报

新软件可编辑演员表情

据2016年2月8日美国媒体消息称,已经出现了可编辑演员表情的新软件。美国迪士尼研究院和塞瑞大学开发的Facedirector软件可以减少电影拍摄的任务量,因为...

30950
来自专栏企鹅号快讯

微信小程序又一次放大招,小程序牵手公众号了!

那么,小程序和公众号打通意味着什么用户流量互导 在今年的上半年,为了给小程序引流。微信只开放公众号跳转小程序的功能,从公众号引流到微信小程序,现在是互相的引流。...

39190
来自专栏理论坞

1 千个从业者就有 1 个交互设计师

转自简书:https://www.jianshu.com/p/32dbf8ba4a6c

13610
来自专栏产品成长日志

最强大脑操作手册-思维导图

今天,互联网带给我们大量工具和无限流量的可能,让一个人也可以独立完成一款产品的研发,上市,推广。

15630

扫码关注云+社区

领取腾讯云代金券