当前位置:首页 > 科技  > 软件

聊聊微服务链路服务

来源: 责编: 时间:2023-12-15 17:18:09 897观看
导读微服务架构图片如果有用户反馈某个页面很慢,我们知道这个页面的请求调用链是 A -----> C -----> B -----> D(图片有误),怎么来定位是由哪个服务引起的问题呢? 更进一步,如果每个服务 Service A,B,C,D 都部署在好几台机

微服务架构

图片图片GAl28资讯网——每日最新资讯28at.com

如果有用户反馈某个页面很慢,我们知道这个页面的请求调用链是 A ----->  C ----->  B ----->  D(图片有误),怎么来定位是由哪个服务引起的问题呢? GAl28资讯网——每日最新资讯28at.com

更进一步,如果每个服务 Service A,B,C,D 都部署在好几台机器上。怎么知道某个请求调用了服务的具体哪台机器呢?GAl28资讯网——每日最新资讯28at.com

图片图片GAl28资讯网——每日最新资讯28at.com

可以明显看到,由于无法准确定位每个请求经过的确切路径,在微服务这种架构下有以下几个痛点:GAl28资讯网——每日最新资讯28at.com

1. 排查问题难度会比较大,解决问题的周期长GAl28资讯网——每日最新资讯28at.com

2. 特定场景很难再次复用GAl28资讯网——每日最新资讯28at.com

3.系统性能瓶颈分析同样也不同意GAl28资讯网——每日最新资讯28at.com

这就需要一个分布式调用链追踪系统。GAl28资讯网——每日最新资讯28at.com

图片图片GAl28资讯网——每日最新资讯28at.com


GAl28资讯网——每日最新资讯28at.com

分布式调用链追踪系统:设计

如果要我们自己实现一个这样的分布式追踪系统,该怎么去设计?GAl28资讯网——每日最新资讯28at.com

首先,我们必须得区分每个调用链,得给它分配一个全局唯一的 TraceID,并且在调用链上的每次调用都带上这个 ID,这样每个调用都被关联起来了。GAl28资讯网——每日最新资讯28at.com

图片图片GAl28资讯网——每日最新资讯28at.com

然后,我们得记录所有调用的先后次序和父子关系。GAl28资讯网——每日最新资讯28at.com

假设有以上这样的调用链,如果我们只记录了这四个调用:GAl28资讯网——每日最新资讯28at.com

A---->BGAl28资讯网——每日最新资讯28at.com

B---->CGAl28资讯网——每日最新资讯28at.com

A---->DGAl28资讯网——每日最新资讯28at.com

D---->EGAl28资讯网——每日最新资讯28at.com

D---->FGAl28资讯网——每日最新资讯28at.com

虽然我们知道它属于一个调用(TraceID 相同),还是无法画出完整的调用拓扑图。GAl28资讯网——每日最新资讯28at.com

所以必须得记录父子关系:GAl28资讯网——每日最新资讯28at.com

A---->B 是 B---->C 的父调用GAl28资讯网——每日最新资讯28at.com

A---->D 是 D---->E 的父调用GAl28资讯网——每日最新资讯28at.com

A---->D 还是 D---->F 的父调用GAl28资讯网——每日最新资讯28at.com

图片图片GAl28资讯网——每日最新资讯28at.com

Agent

微服务是来实现业务的,肯定不能来干这个监控和跟踪的活儿,那样对微服务的侵入性就太强了。GAl28资讯网——每日最新资讯28at.com

所以必须得有一个独立的组件,在不干扰微服务的情况下,监控微服务之间的调用,把这些 ID 生成, 这个独立的组件就是 Agent。GAl28资讯网——每日最新资讯28at.com

Agent 要想施展魔法,需要安装在每个服务所在的机器上:GAl28资讯网——每日最新资讯28at.com

图片图片GAl28资讯网——每日最新资讯28at.com

这个魔法师遵循的规则也非常简单,以上图中服务 A 上的 Agent 为例:GAl28资讯网——每日最新资讯28at.com

当 Agent 监测到有人调用服务 A 时,没有 ParentSpanID,它意识到这是一次全新的调用,于是创建新的 TraceID。GAl28资讯网——每日最新资讯28at.com

当 Agent 察觉到 A 调用了 B 时,生成 SpanID = 1,并将此 ID 作为 ParentSpanID 传递给 B。这样,当 B 调用 C 时,B 的 Agent 就能生成此次调用的 SpanID 为 1.1。GAl28资讯网——每日最新资讯28at.com

当 Agent 察觉到 A 调用 D 时,生成 SpanID = 2,并将此 ID 作为 ParentSpanID 传递给 D。GAl28资讯网——每日最新资讯28at.com

4. 在 D 调用 E 和 F 时,分别生成 SpanID 2.1 和 2.2。GAl28资讯网——每日最新资讯28at.com

指定微服务中的“RPC 调用的公用程序”(例如 Dubbo 中的 MonitorFilter.invoke方法), 然后在运行时,通过动态修改字节码的方式来增强它:GAl28资讯网——每日最新资讯28at.com

图片图片GAl28资讯网——每日最新资讯28at.com

当服务 A 调用服务 B 时, Agent 就可以做点儿手脚,修改 header 了:GAl28资讯网——每日最新资讯28at.com


GAl28资讯网——每日最新资讯28at.com

图片图片GAl28资讯网——每日最新资讯28at.com

数据收集

Agent 虽然监控、生成了足够多的数据,但是单个 Agent 无法获得全局视图,我们需要一个全局的收集器来把 Agent 的数据收集上来,这样才能生成全局的调用链。GAl28资讯网——每日最新资讯28at.com

结构如下图:GAl28资讯网——每日最新资讯28at.com

图片图片GAl28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-46491-0.html聊聊微服务链路服务

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 九个免费开源的GIF编辑器

下一篇: 如何回溯解决组合问题和字符串分割

标签:
  • 热门焦点
  • 鸿蒙OS 4.0公测机型公布:甚至连nova6都支持

    华为全新的HarmonyOS 4.0操作系统将于今天下午正式登场,官方在发布会之前也已经正式给出了可升级的机型产品,这意味着这些机型会率先支持升级享用。这次的HarmonyOS 4.0支持
  • K60至尊版狂暴引擎2.0加持:超177万跑分斩获性能第一

    Redmi的后性能时代战略发布会今天下午如期举办,在本次发布会上,Redmi公布了多项关于和联发科的深度合作,以及新机K60 Ultra在软件和硬件方面的特性,例如:“K60 至尊版,双芯旗舰
  • 俄罗斯:将审查iPhone等外国公司设备 保数据安全

    iPhone和特斯拉都属于在各自领域领头羊的品牌,推出的产品也也都是数一数二的,但对于一些国家而言,它们的产品可靠性和安全性还是在限制范围内。近日,俄罗斯联邦通信、信息技术
  • 天猫精灵Sound Pro体验:智能音箱没有音质?来听听我的

    这几年除了手机作为智能生活终端最主要的核心之外,第二个可以成为中心点的产品是什么?——是智能音箱。 手机在执行命令的时候有两种操作方式,手和智能语音助手,而智能音箱只
  • 0糖0卡0脂 旭日森林仙草乌龙茶优惠:15瓶到手29元

    旭日森林无糖仙草乌龙茶510ml*15瓶平时要卖为79.9元,今日下单领取50元优惠券,到手价为29.9元。产品规格:0糖0卡0脂,添加草本仙草汁,清凉爽口,富含茶多酚,保留
  • JavaScript 混淆及反混淆代码工具

    介绍在我们开始学习反混淆之前,我们首先要了解一下代码混淆。如果不了解代码是如何混淆的,我们可能无法成功对代码进行反混淆,尤其是使用自定义混淆器对其进行混淆时。什么是混
  • 共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • “又被陈思诚骗了”

    作者|张思齐 出品|众面(ID:ZhongMian_ZM)如今的国产悬疑电影,成了陈思诚的天下。最近大爆电影《消失的她》票房突破30亿断层夺魁暑期档,陈思诚再度风头无两。你可以说陈思诚的
  • 自研Exynos回归!三星Galaxy S24系列将提供Exynos和骁龙双版本

    年初,全新的三星Galaxy S23系列发布,包含Galaxy S23、Galaxy S23+和Galaxy S23 Ultra三个版本,全系搭载超频版骁龙8 Gen 2,虽同样采用台积电4nm工艺制
Top