spring中责任链模式的使用场景(在Ceph中使用)
spring中责任链模式的使用场景(在Ceph中使用)
2024-06-26 07:19:23  作者:小蛋壳  网址:https://m.xinb2b.cn/know/zre123697.html

云和安全管理服务专家新钛云服 祝祥翻译

什么是分布式跟踪?

分布式跟踪是用来查看和了解复杂的微服务间交互中的整个活动链。

现代的云原生软件开发十分依赖微服务,因为每个独立的服务都提供不同的核心功能。当用户在应用中发出请求时,许多单独的服务都会做出响应,产生相应的结果。

应用中的一个调用可能会涉及几十项彼此交互的服务。当出现问题或某个请求变慢时,开发人员和工程师该如何查明问题所在?所以我们需要一种能跟踪所有连接的方法。

这就是分布式跟踪的意义所在。它通常是作为服务网格(管理和监控微服务的一种方式)的一部分运行。

Jaeger 使用分布式跟踪来了解不同微服务的请求路径。我们可以直观地看到调用流,无需凭猜测工作。

整理有序的事务信息对于调试和优化而言非常有用。Jaeger 内含的工具可用于监控分布式事务、优化性能和延迟,以及执行根本原因分析(RCA)(一种问题解决方法)。

Jaeger 组件及相关术语

作为一个开源项目,一个由数百个贡献者组成的社区不断改进完善着 Jaeger。Jaeger 基于与供应商无关的 OpenTracing API 和工具。

共享出行公司 Uber 在 2015 年开发了开源项目 Jaeger。2017 年,Jaeger 纳入云原生计算基金会(CNCF)的孵化项目,2019 年,Jaeger 正式毕业。

Jaeger 将执行请求显示为一条条迹线(trace)。迹线代表系统中的数据/执行路径。

一个迹线包含一个或多个跨度(span)。跨度是 Jaeger 中作业的逻辑单元。每个跨度都由作业名称、开始时间和持续时间组成。跨度可以进行嵌套和排序。

Jaeger 内含多个组件,这些组件可以协同工作,一起收集、存储和可视化跨度与迹线。

Jaeger 客户端包括含用于分布式跟踪的 OpenTracing API 的特定语言实施。您可以手动使用这些实施,也可以将其与各种开源框架一起使用。

Jaeger 代理是一个网络守护进程,可侦听通过用户数据报协议发送的跨度。该代理应与所检测的应用放置在同一主机上。这通常是通过 Kubernetes 等容器环境中的 sidecar 实现的。

Jaeger 收集器可接收跨度并将它们放在队列中等待处理。

收集器需要持久的存储后端,因此 Jaeger 还具有可插拔的跨度存储机制。

查询是一项从存储中检索迹线的服务。

Jaeger 控制台是一个用于可视化分布式跟踪数据的用户界面。

Ceph与Jaeger

Ceph是一个统一的分布式存储系统,设计初衷是提供较好的性能、可靠性和可扩展性。

Ceph项目最早起源于Sage就读博士期间的工作(最早的成果于2004年发表),并随后贡献给开源社区。在经过了数年的发展之后,目前已得到众多云计算厂商的支持并被广泛应用。RedHat及OpenStack都可与Ceph整合以支持虚拟机镜像的后端存储。

spring中责任链模式的使用场景(在Ceph中使用)(1)

像 Ceph 这样的分布式系统可能是调试的噩梦,因为它们没有单点故障。为了解决这个问题,我们一直致力于向 Ceph 添加一个标准的分布式跟踪解决方案Jaeger。Jaeger 是一个分布式追踪开源库,是 CNCF 下的一个项目。Jaeger 将提供对 Ceph 分布式后台进程的更多可见性,并帮助用户识别异常,从而“使 Ceph 更加透明”。

本文提供了一个学习使用跟踪调试 Ceph 的机会——非常适合那些希望识别分布式事务中的性能瓶颈、延迟优化和异常的人。

我们很高兴地宣布在 Ceph Pacific版中对 Jaeger 的初步支持!

它是如何工作的?

Jaeger(https://www.jaegertracing.io/docs)(跟踪后端)与Opentracing(https://opentracing.io/docs/supported-tracers/) (API ) 一起为分布式系统提供即用型跟踪服务,并因其简单性而成为广泛使用的事实上的标准。

Jaeger 负责收集 span。这些跨度是使用智能指针制作的。它们包括时间戳、TraceID 和其他元信息,例如与跨度关联的特定标签/日志,以便在分布式系统中唯一标识。然后将这些相关联以生成请求生命周期的可视化(跟踪)。

spring中责任链模式的使用场景(在Ceph中使用)(2)

让我们试试吧!

让我们来看看跟踪 Ceph 的输入-输出事务中涉及的核心功能。如果您设置了 jaeger 后端以使用 Ceph,请跳过下一节。

有关如何设置的信息,请参阅文档:https://docs.ceph.com/en/latest/dev/developer_guide/jaegertracing/

部署 Jaeger 服务

我们将使用 vstart 开始跟踪。

为此,请确保您有:

Ceph 配置了WITH_JAEGER=ON.部署 jaeger 后端服务 - 要使用 vstart 开发集群部署 Jaeger 后端服务,您只需要传递--jaeger选项。

$ ../src/vstart.sh --jaeger

按照上述步骤,您应该能够设置所有 Jaeger 服务并通过http://localhost:16686访问JaegerUI。

更多可以阅读:https://www.jaegertracing.io/docs/1.20/getting-started/#all-in-one

spring中责任链模式的使用场景(在Ceph中使用)(3)

(JaegerUI 在http://localhost:16686)

如果由于某种原因您无法访问 JaegerUI,请使用以下命令重试手动运行 Jaeger 服务:

$ docker run -d --name jaeger \-e COLLECTOR_ZIPKIN_HTTP_PORT=9411 \-p 5775:5775/udp \-p 6831:6831/udp \-p 6832:6832/udp \-p 5778:5778 \-p 16686:16686 \-p 14268:14268 \-p 14250:14250 \-p 9411:9411 \jaegertracing/all-in-one:1.20

追踪核心服务

现在我们已经启动并运行了 Jaeger 服务,让我们来看看 Ceph 的核心服务跟踪。

Ceph 目前可以跟踪 OSD I/O 路径中的操作,我们将在这里演示:

我们将执行一个简单的写操作,为此我们使用 rados bench write。您可以使用您选择的任何其他可用的写入接口。

[ideepika@vossi03 build]$ bin/ceph osd pool create test; //create a pool[ideepika@vossi03 build]$ bin/rados -p test bench 5 write --no-cleanup //perform a rados bench write for 5 sec

在刷新 JaegerUI ( http://localhost:16686 ) 时,您应该能够在 services 字段中看到 osd-services,它指定了请求生命周期中跟踪的 OSD 进程。

spring中责任链模式的使用场景(在Ceph中使用)(4)

spring中责任链模式的使用场景(在Ceph中使用)(5)

正下方是“操作”字段,其中列出了收集的跨度,单击该字段将为您提供包含它的跟踪。

spring中责任链模式的使用场景(在Ceph中使用)(6)

我们看到了我们最近的写操作收集的轨迹列表,以及一个 x(time)-y(duration) 图,轨迹作为数据点。

spring中责任链模式的使用场景(在Ceph中使用)(7)

spring中责任链模式的使用场景(在Ceph中使用)(8)

当您单击任何跟踪时,它应该扩展到存储在其中的所有跨度和元数据。

spring中责任链模式的使用场景(在Ceph中使用)(9)

我们可以在创建跨度时以标签和日志的形式存储 Ceph 的元数据,如下所示;携带 Ceph 相关元数据的日志字段。

spring中责任链模式的使用场景(在Ceph中使用)(10)

在那里你可以看到你的内部流程!

将跟踪导出为 JSON

这些痕迹是便携式的!它们可以转换为 JSON 输出,可以使用 JaegerUI 在其他系统上呈现。

spring中责任链模式的使用场景(在Ceph中使用)(11)

下一步任务

这个项目仍在进行中,但是有了作为实时跟踪的正确信息的编排,我们将有一个端到端跟踪,这可以使调试更加容易,从而了解Ceph的内部结构!

我们期待提高 Ceph 的整体可观察性。

我们准备了一些任务来改进跟踪支持,将跟踪支持扩展到客户端(RGW、CEPFS、RBD),并与OSD跟踪集成,改进部署策略,从而能够实时监控系统运行状态以及服务部署情况。

原文:https://ceph.com/en/news/blog/2021/distributed-tracing-in-ceph-using-jaeger/

  • 天气降温的祝福短信(盘点天气降温的祝福短信)
  • 2024-06-26盘点天气降温的祝福短信眼看就要小寒了,送你一件外套吧,用真心做面料,以爱心为线,内层绣上祝福,夹层用上温馨棉,最后系上关心扣,天冷好好照顾自己天寒北风在怒吼,背窗雪落炉烟直,冬日天气虽多变,朋友之情依然传,日日思念在心间,。
  • 酸菜炖肉容易软烂(酸菜炖肉直接下锅绝对又腥又苦)
  • 2024-06-26酸菜炖肉直接下锅绝对又腥又苦大家好,我是第一美食的阿飞,关注阿飞有更多的家常菜供大家参考!听说东北的朋友炖肉的时候都很爱放酸菜,然后有一天我就问了一个朋友原因,他说其实他们不是炖肉的时候放酸菜,而是想吃酸菜的时候配点肉……那么酸。
  • 科大讯飞录音笔sr101使用攻略(科大讯飞SR701录音笔)
  • 2024-06-26科大讯飞SR701录音笔由于不同用户之间需求差异较大,录音笔关键技术发展在过去一段长的时间内并没有多大的升级,而且主要的还是集中在如何提升录音质量上但是随着AI时代的来临,录音笔通过AI语音技术的加持获得了一次技术提升的良好。
  • 直播卖花的直播间(新引擎大山里的直播间)
  • 2024-06-26新引擎大山里的直播间编者按今年3月6日,在决战决胜脱贫攻坚座谈会上强调,脱贫摘帽不是终点,而是新生活、新奋斗的起点4月20日,在陕西柞水县金米村考察时说:“电商,在农副产品的推销方面是非常重要的,是大有可为的”当前,接续。
  • 蚕豆的喜好(巢湖纪事闲话蚕豆)
  • 2024-06-26巢湖纪事闲话蚕豆作者:唐元红“立夏前三天没得吃,立夏后三天吃不彻(彻,方言音chai四声意为撵不上)正是蚕豆上市的时节,这句话在乡人的口中被反复地念叨着这不,前天吃起来还水嫩嫩的蚕豆米,今天就面嘟嘟的了餐桌上一盆韭菜。
  • dnf影舞者加点图(DNF影舞者皮轻B套分析)
  • 2024-06-26DNF影舞者皮轻B套分析不同的职业需要不同的装备,看到很多职业有自己的b套讨论,那么我来为心爱的职业影舞者做一次分析,希望能对坚持影舞者这个职业的朋友有些许帮助废话不多说,第一张图是建模过程,考虑了一下小康玩家所能达到的标准。
  • 高中生物题型及解题技巧(高中生物常考题型)
  • 2024-06-26高中生物常考题型➤题型一:曲线类答正确解答曲线坐标题的析题原则可分为识标、明点、析线三个步骤:1、识标:弄清纵、横坐标的含义及它们之间的联系,这是解答此类习题的基础2、明点:坐标图上的曲线有些特殊点,明确这些特殊点的。
  • 全球最大规模慈善演唱会(筹款1.3亿美元一场最伟大的)
  • 2024-06-26筹款1.3亿美元一场最伟大的今日凌晨,无论是混日韩圈、欧美圈还是内娱圈的粉丝,热爱电影的文艺青年,还是热爱音乐的发烧友,都在共同期待这场见证人类历史的线上演唱会众神云集之时,没有绚烂迷幻的舞台、没有狂热粉丝的尖叫呼喊,有的只是着。
  • 梦的解析和感想(让我们一起来解读自己的梦吧)
  • 2024-06-26让我们一起来解读自己的梦吧梦是回忆过去还是预示未来许多非西方群体关于梦的文化实践也反映了本质不同的时间观弗洛伊德的理论对梦的解释是回顾过去,朝向儿童期的经历和压抑的愿望在许多其他的文化中,梦被认为是对未来的想象在埃塞俄比亚和苏。
  • nt是什么网络语(nt的意思)
  • 2024-06-26nt的意思nt,网络流行语,原意为英文nicetry(好的尝试)的缩写,后成了noobteam和脑瘫的缩写,成为了带有贬义但又相对婉约的说法nt原意为英文nicetry(好的尝试)的缩写,常见于竞技类网游中的玩。