AICon日程100%就绪,9折倒计时最后一周 了解详情
写点什么

微服务架构搭好了,可观测方案怎么整?

  • 2022-07-19
  • 本文字数:5437 字

    阅读完需:约 18 分钟

微服务架构搭好了,可观测方案怎么整?

差不多在五年前,分布式系统也已成熟,微服务架构尚未普及,可观测问题就已经在桎梏技术团队的工作效率。一个 To C 的软件使用问题可能由客服发起,整条支撑链路的所有技术部门,都要逐一排查接口和日志,流程非常原始,也非常低效。如果业务到达一个量级,支撑系统变多,两名研发查上两三个星期也是常事。

 

微服务架构普及后,问题变得更加严峻。一个服务被拆分成数个黑盒的、虚拟的微服务,故障排除彻底成为一种折磨。这一切都使业务的可观测性成为 2022 年技术人必须关注的话题。本期《极客有约》,我们邀请到博睿数据创始人兼 CTO 孟曦东和某头部证劵公司 SVP 的周洪一起聊聊可观测技术究竟是什么?


00:00 / 00:00
    1.0x
    • 3.0x
    • 2.5x
    • 2.0x
    • 1.5x
    • 1.25x
    • 1.0x
    • 0.75x
    • 0.5x
    网页全屏
    全屏
    00:00


    InfoQ:微服务架构的普及对可观测带来了一些挑战,这些挑战又让运维领域发生了怎样的变化?

     

    孟曦东:可观测不是一个新名词。2018 年,CNCF 将其正式引入 IT 世界,该理论的出现则可以追溯至 2014 年前后,主要来自于控制学,希望通过外部输出推断内部的状态变化。如今,技术栈发生了巨大变化,微服务可能构建在容器之上,容器又构建在虚拟机上,虚拟机则在物理机上,包括更复杂的网络支持,这让定位排障遇到了前所未有的困难。CNCF 之所以将可观测性带到微服务领域也是希望能有更好的能力控制系统的运行状态。

     

    与传统的监控相比,可观测性的核心点还是有所区别的。监控可能更多在看现实状态的变化,很直接,但并没有表现出问题的核心点在哪。我们认为可观测性是对现今技术架构非常好的适应,可以用另外一种模型来判断风险所在位置,能更好地预防故障发生而不是简单地降级、限流。

     

    InfoQ:在实际应用当中,企业对可观测性的实际感受是什么样的?

     

    周洪:我们面临着线上问题的排查困难,包括一些链路追踪的困难。特别是证券业务对高可用有非常高的要求,某一个业务出现问题可能无法通过降级和限流来解决,对客户来讲还可能面临着经济上的损失,我们对链路的观测,对链路问题的追踪,对链路服务质量有非常高的要求。在技术架构的升级和演进过程中,我们面临着两类比较难以解决的问题,分别是全链路故障定位及解决和缺少相对全局的视角。

     

    InfoQ:如今,大部分企业还停留在粗暴的降级阶段,还是有意识做全局可监控?

     

    孟曦东:可以分成两类,一类是发展靠前的企业,在业务体验或者用户感知能力上面要求较高,内部对此有很多 KPI,比如出现问题需要一分钟内发现,十分钟内解决等;另一类是农林牧副渔等领域的传统企业,目前手段还比较初级,只做到了单体的简单监控,整个上层的应用体系还没有完整建立起来。

     

    InfoQ:具体到技术层面,可观测问题可以分为四类,分布式链路追踪、APM、NPM、RUM,方便介绍下这四者的核心思想吗?

     

    孟曦东:从可观测性的建设体系来看,需要有三种类型的数据。RUM 可能更多关心的是用户侧,比如用户到底在使用浏览器、APP 还是小程序,使用体验如何或者整个运行过程中的数据能力是如何表现出来的;NPM 可能更多在描述链路层面,因为这是必备通道,是建立从前端到后台连接的必备过程,在描述整个数据流向的时候,流量数据又是什么样的表现;APM 把物理设备层面的能力提升到了以应用代码级为主,可以看最详细的代码状态,或者依赖的中间件以及 JVM 状态变化。整个链路追踪分段做数据采集,数据来源可能不同,但模型的核心是构建出一套完整的数据链条来帮助我们更好地判断业务受损到底是由哪个环节产生的问题。

     

    InfoQ:APM 做到代码级别之后,还有进一步的改进空间吗?

     

    孟曦东:改进空间肯定还是有的。第一,全链路可观测性需要了解代码的整体逻辑,这样才能更好地知道版本迭代时前后接口的变化;第二,我们也需要知道彼此之间的依赖项是什么,从技术内部来看,链路是非常多样化的,尤其是引用了容器云之后,随着 Pod 的增加和减少,链路变得错综复杂并且更加动态,我们需要有更完整的信息数据来支撑我们做故障定位。

     

    InfoQ:国内外目前在可观测领域的技术发展现状大概是什么样的?

     

    孟曦东:相对于国外来说,国内起步稍晚,我们可以看到国外有很多优秀的友商,在可观测能力的构建上已经非常成熟,他们还与 DevOps 做融合,加强安全方面的能力等。我认为国内在可观测性领域属于起步阶段,以博睿数据为例,我们今年才真正构建所谓的一体化全栈解决方案。

     

    InfoQ:贵司目前的监控体系大概是如何组建的?

     

    周洪:我们处于典型的起步阶段,基本采用采购加自研的方式,采购是针对一些比较成熟的产品,可以提供标准化的监测,包括流量、耗时、错误等。同时,我们会自己做一些定制化研发,包括从 NPM 拿数据,从支持拿数据,自己再做串联。这种方式的弊端可能是要投入相当一部分人力。当然效果还是比较明显的,在关键业务上,我们已经可以实现所谓的全链路监测。但是还有一些相对非核心的业务,边缘化的业务,由于企业自身的自研能力再加上资源投入的不足,可能还有进一步的改善空间。

     

    InfoQ:如何快速低成本地构建业务系统的可观测性?

     

    孟曦东:构建一个所谓的可观测性系统有三个要素,一是要有数据;二是背后有一个强大的异构能力的数据引擎;三是需要有高效的查询。最直接经济的方案是看现在的情况是什么样的,哪些需要采购商业化的产品,哪些选择开源项目或者自研,最终对整体进行拼凑,这种方式会高效一些。

     

    InfoQ:能否聊一下目前建设可观测体系通常的路径,比如说什么类型,或者什么规模的企业?

     

    孟曦东:大体分为三类,第一类是自研的,比如头部的互联网公司,自己的研发实力或者研发资源非常多,在公司的发展过程中沉淀了很多有价值的东西;第二类是基于开源做二次构建,比如腰部的公司,打磨出一个可能适合自己或者组织规模的模型,或许 APM 就可以,不一定是可观测的解决方案;第三类是全部采买三方软件,通过这种方式构建可观测的能力平台。

     

    InfoQ:有什么流程体系去评估是否应通过外采的方式?

     

    周洪:我们有三大衡量标准。一是市场的标准化程度是否足够高,监控本身的效率及系统稳定性;二是全链路监控而非单点监控,是否具备全业务场景的组合能力,是否可以配置化的形式完成组合业务监控;三是是否具备一些更高级的功能,比如业务异常检测、报警规则、自动发现等措施的智能化程度。

     

    InfoQ:目前市场上提供这种可观测的商用产品是不是也不多?

     

    孟曦东:国外的产品不少,因为今年 Gartner 的 APM 领域调研报告也增加了可观测性象限,其中列出了一些新型公司。谈到可观测性需要解决的核心问题,也就是数据来源、对数据的理解以及分析利用,国内市场能完整覆盖的方案少之又少,国外在该领域的纯商业化公司更多一些。

     

    InfoQ:大家比较熟知的项目 SkyWalking 是否适合微服务的架构?

     

    孟曦东:SkyWalking 本身应该定义在 APM 领域更合适。如果是微服务,对探针端的能力是有要求的,据我们现在看到的,SkyWalking 还没有真正做到类似商业公司的探针技术,还做不到全智能的基于 K8s 的直接部署,动态探针以及自动命名。

     

    InfoQ:可观测性技术在解决数据孤岛方面的作用是什么?

     

    孟曦东:大多数用户的监控系统还是比较多的,可能有几套到十几套不等,因为监控系统也有可能是由于不同的组织内部不同的部门构建的,这样就势必会造成一个问题,因为没有从上层做统筹安排,把这些系统真正有机地组成在一起,供所有业务方去真正消费,孤岛问题就比较严重。我们希望能把数据从相互割裂的体系里面抽取出来,做一个统一的描述的模型,然后供不同的业务方去消费。不管是报警场景,还是运维场景,都可以落地到实际的业务场景里面,这样才能真正拉通。我们有一个很重要的特性就是三方数据的开放性或者兼容性,可以把现有的标准集成到一个平台里面,做统一的标准化,统一的模型建设,统一的落盘,然后再抛掉上层做不同场景的消费能力的支持。

     

    InfoQ:AI 在监控领域的作用?

     

    孟曦东:AI 赋能到监控领域分为几大方面的作用:第一也是最重要的是根因分析的能力,基础是建立一体化的数据平台;第二是希望可以做自动化的框架,不管是第三方的还是商业化的,通过我们的判断触发一些信息让业务做更有价值的动作,让人力可以得到释放。

     

    InfoQ:如何看待国内可观测厂商 SaaS 发展的一个前景?

     

    孟曦东:很多人都提出国内的 SaaS 发展与北美差异较大,我个人认为有几个要素:一是国内的市场环境或者技术栈还未到一定程度,北美也是从基础监控、做日志、做 APM 慢慢累积到现在这个程度的,美国云计算的发展领先中国五六年的时间,所以北美很多业务应用更习惯于放在几大云上;第二,国内存在一些行业政策的监管要求,比如金融领域可能有一些数据方面的安全要求,这也就限制了公有云标准化 SaaS 能力的交付;第三,产品能力,这个问题不该回避,国内的可观测能力确实还在起步阶段,在整个能力构建图谱上还有差距,如果产品没有打磨好或者没有特别好的能力价值输出,就会影响客户的买单意愿。

     

    InfoQ:OpenTelemetry 项目目前在可观测领域比较受欢迎,这是为什么?

     

    孟曦东:首先,OpenTelemetry 将原来部分定义的标准真正体系化了。我们很早就有了 OpenTracing ,但那只是定义了追踪数据的标准格式。任何企业或组织的技术人员,都希望能把某些能力标准化,这样不管是兼容第三方,还是自我迭代都会有一致性或者维护成本方面的好处。其次,该项目提供了非常丰富的 SDK 和 API 能力,可以让开发者和企业快速使用。最后,该项目基于 CNCF 基金会,其中有很多优秀的人物制订了标准。

     

    InfoQ:在生产环境当中,如何选出靠谱的工具去解决可观测性的问题?

     

    孟曦东:在生产中,环境是多样的,我们首先要找到能与当前业务发展情况较好匹配的工具,毕竟每一款工具或者平台都不是万能的,企业会有很多个性化的要求。对于企业级服务,是不是真的有一些标准或者制度可以约束出来,提供给 IT 人员做问题定位。在整个工作流里面,QA 测试完以后是否能覆盖到所有场景。我们认为,对任何企业或者 IT 组织来讲,APM 工具都是必备的,因为可以把不同角色的人用同一种话术连接在一起。我们做运维、研发,或者业务 Owner,需要一个平台把这些标准融合在一起,避免大家产生不必要的纠纷。在 APM 之外,用户肯定还会再构建更完整的能力平台,因为不能只看到内部,还要看到除了数据中心以外的人的反应。因为这部分可能还会需要依托互联网,依托前端业务应用场景定位可能产生的问题,我认为这是一个有机的组合,根据不同的阶段以及人群使用场景构建出一套自己的体系。

     

    InfoQ:对于同样想构建可观测能力的企业有没有什么比较好的建议?

     

    周洪:第一,无论是监测系统还是业务系统,我们关注的是系统本身的稳定性,监测系统的目的是监测本身的应用系统,通过监测发现应用系统的问题,这对我们来讲至关重要,否则一旦出现生产问题,不知道是怀疑监测系统出了问题,还是怀疑业务系统出了问题,这对甲方来说会带来灾难性的后果。

     

    第二,希望能做到更加体系化甚至全家桶方案,作为应用性的企业,我们还是希望把更多的精力放到业务上,提高业务实战水平,通过解藕的方式把监测体系搭建起来,如果本身对应用系统的入侵很大,甚至说影响到业务系统的信赖,就有点得不偿失了。

     

    InfoQ:博睿数据前段时间也在可观测这部分做了一些事情,发布了一体化智能可观测平台 ONE,我们怎么理解这里面的“一体化和智能可观测”?

     

    孟曦东:一体化,我们认为就是要全面,数据能力要能覆盖到整个系统的云管边端的全数据链条。第一步是用三方能力接入或者博睿数据提供自己的数据采集能力把它构建起来。第二步体系化或者标准化的过程,真实构建一个立体的组织模型,否则会导致治理或者定义指标能力时出现混乱。第三步,我们认为一体化也是为 AI 提供一个底座,我们认为未来 AI 的价值不可或缺,在主动巡检、过程中的异常监测以及后面的根因分析,AI 技术在其中发挥了很大的价值。

     

    InfoQ:国内目前可观测市场的未来发展技术方向是什么?博睿数据后续有什么规划?

     

    孟曦东:如果我们认为 IT 运维是为了业务做服务或者做支撑,不是成本中心,IT 本身就会离业务越来越近,这肯定是一个必不可少的发展路径。反过来想,希望 IT 输出的价值可能也会发生改变,所以我们认为可观测性本身的核心定义就是 Google 谈的定位问题。如果业务是敏捷的,某个时间点的弹性或者高可靠无法代表全局。随着业务规模的逐渐膨胀,可观测性需要真正把冲突从根上解决,因为最终还是要定位问题,通过定位到的问题做好事前的风险防范、事中的问题排障以及事后的反思。我认为可观测性肯定是未来,不管是由于云计算还是其他技术的发展。

     

    博睿数据今年希望先把一体化做扎实,再在其上构建其他的能力模块。现在因为测试左移越来越流行,我们准备将安全与 DevOps 结合在一起,同时在知识库和其他一些 ITSM 工具的整合上面下功夫,希望能帮助到客户做成一个有机的定位平台。

     

    InfoQ:贵司后期在可观测领域会做哪些层面的事情?

     

    周洪:因为我们是应用方,对我们而言,监测本身不是我们的目的,我们的目的是通过监测间接提升整个服务质量和服务水平。我觉得我也代表广大用户给博睿数据等厂商在千亿级别的发展道路上提一些需求:一是希望把监测做得更加精细化;二是注重场景化诉求,我们已经建立了几千个黄金指标、业务指标,如何快速通过编排或者商业结合准确反应到真正的业务监测链路上,而不需要每次根据业务做一些定制化的开发;三是再进一步做到智能化。

     

    讲师介绍:

     

    孟曦东,博睿数据创始人兼 CTO。1998 年 8 月至 2000 年 3 月,任中国航空第 303 研究所软件工程师;2000 年 3 月至 2008 年 1 月,任北京千龙新闻网络传播有限责任公司技术总监;2008 年 2 月至 2016 年 2 月,任博睿数据首席技术官;自 2016 年 2 月至今,任博睿数据董事、副总经理。

     

    周洪,某头部证劵公司 SVP

     

    2022-07-19 08:1213088
    用户头像
    赵钰莹 InfoQ 主编

    发布了 882 篇内容, 共 643.2 次阅读, 收获喜欢 2679 次。

    关注

    评论

    发布
    暂无评论
    发现更多内容

    上游思维:在系统的关键处找一个支点

    石云升

    读书笔记 8月日更 上游思维

    🏆【分布式技术专题】【分布式技术专题】RocketMQ延迟消息实现原理和源码分析

    洛神灬殇

    RocketMQ 延时队列 8月日更 DelayedQueue

    基于springcloud springboot vue elementui商城源码毕设实战

    清风

    Vue Java 分布式 毕业设计

    2021 OceanBase 数据库大赛来袭!邀你改编世界,码出未来

    OceanBase 数据库

    数据库 oceanbase OceanBase 开源 OceanBase 社区版 OceanBase 数据库大赛

    GIT远程仓库

    一个大红包

    8月日更

    java springboot微信小程序授权登录开发

    清风

    小程序 java小程序

    敏捷开发

    LeifChen

    Scrum 敏捷开发 迭代 8月日更

    蔚来事故背后,“致命弯道”在辅助驾驶和自动驾驶之间

    脑极体

    还在死磕 Ajax?那可就 out 了!

    编程三昧

    JavaScript 大前端 8月日更 Fetch

    架构实战营模块五作业

    maybe

    ipfs挖矿是怎样赚钱的?ipfs挖矿值得投资吗?

    IPFS挖矿值得投资吗 IPFS挖矿是怎样赚钱的

    CODING DevOps 高级架构师王炜入选木兰开源社区首批导师

    CODING DevOps

    DevOps Nocalhost 木兰开源社区 开发者生态

    Go- 变量

    HelloBug

    变量 Go 语言

    Magician has released a new version

    Magician网络编程包

    Java Web 网络编程 io nio

    ipfs矿机公司实力排行如何?ipfs矿机排名如何?

    ipfs矿机公司实力排行如何 ipfs矿机排名如何

    从0开始的TypeScriptの十:泛型

    空城机

    typescript 大前端 8月日更

    Go- 常量

    HelloBug

    常量 const Go 语言

    简简单单实现 Python Web 的登录注册页面,还包含一半逻辑。

    梦想橡皮擦

    8月日更

    耗时24小时整理了网络安全学习路线,非常详细!

    网络安全学海

    黑客 网络安全 信息安全 渗透测试 漏洞挖掘

    【架构设计模块五】:设计微博系统中”微博评论“的高性能高可用计算架构

    Ryoma

    python3学习笔记-20210817(变量名与字符串)

    姬翔

    微服务架构师-docker私有镜像仓库的配置和使用

    学神来啦

    Linux 容器 微服务 运维 架构师

    云原生时代到来了么?

    escray

    学习 极客时间 如何落地业务建模 8月日更

    破解AI开课难题!2021 全国人工智能师资培训落地厦门大学

    百度大脑

    人工智能

    高可用架构(下)

    编号94530

    数据库 架构设计 异地多活容灾 高可用架构

    OceanBase源码解读(二):SQL的一生

    OceanBase 数据库

    数据库 分布式数据库 oceanbase OceanBase 开源 OceanBase 社区版

    Flink 和流式应用运维(十-上)

    Databri_AI

    flink API REST API

    DAPP去中心化交易所开发|DAPP与APP的区别

    Geek_23f0c3

    交易所开发 去中心化交易所系统开发 DAPP智能合约交易系统开发

    「最好」的敌人是「好」

    非著名程序员

    提升认知 认知提升 个人提升 8月日更

    Go-基本元素

    HelloBug

    Go 语言

    JavaScript单元测试的“抹茶”组合:Mocha和Chai

    devpoint

    JavaScript 单元测试 8月日更

    微服务架构搭好了,可观测方案怎么整?_语言 & 开发_赵钰莹_InfoQ精选文章