spring中责任链模式的使用场景(在Ceph中使用)
spring中责任链模式的使用场景(在Ceph中使用)
2024-11-22 12:05:20  作者:小蛋壳  网址:https://m.xinb2b.cn/tech/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整合以支持虚拟机镜像的后端存储。


像 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 和其他元信息,例如与跨度关联的特定标签/日志,以便在分布式系统中唯一标识。然后将这些相关联以生成请求生命周期的可视化(跟踪)。


让我们试试吧!

让我们来看看跟踪 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


(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 进程。



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


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



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


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


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

将跟踪导出为 JSON

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


下一步任务

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

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

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

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

  • 去看坐月子的朋友送什么给宝宝(去看月子里的新生儿)
  • 2024-11-22去看月子里的新生儿好多朋友问我,去看新生儿应该带什么礼物比较好?太贵的送不起,太便宜拿不出手,要品牌好,知名度高,提在手上有点份量下边推荐几个适合月子送礼的的产品,另外,给自己宝宝用也一样适宜尿不湿超薄纸尿裤虽然送礼不。
  • 红枣和黑芝麻可以打成糊状(这3种米和红枣打成糊)
  • 2024-11-22这3种米和红枣打成糊生活水平的提高,人们的健康意识也随着提高,在日常的饮食中,人们越来越重视饮食的健康问题和保健作用,开始向健康饮食方面去转变说到食物,有一些杂粮米受到了很多人的喜欢,尤其是女士的喜欢除了这些杂粮米饱腹感。
  • 另类元宵节的过法(关于元宵节打货郎杆)
  • 2024-11-22关于元宵节打货郎杆文/一生平安山西省武乡县故城镇一带,每年正月十五闹秧歌,老百姓叫“闹红火”,十五后半夜秧歌队就开始“刮街”,刮的明了也就是五点左右就开始一家一家挨住窜院开头是锣鼓队,后面跟着打红旗的半大后生,还有小娃。
  • 鸡血烧汤怎样做(鸡血烧汤制作方法教学)
  • 2024-11-22鸡血烧汤制作方法教学原料:豆腐(南)100克,虾米10克,鸡血50克,鸡肉50克,菠菜50克,鸡蛋50克调料:香油2克,盐3克,味精2克,胡椒粉3克,醋8克,淀粉(玉米)5克鸡肉切丝,豆腐和鸡血切成小条海米用沸水泡发好菠。
  • Windows上哪款卸载软件最值得推荐
  • 2024-11-22Windows上哪款卸载软件最值得推荐CCleaner说到卸载软件,就不得不提大名鼎鼎的Windows系统清理工具CCleaner使用CCleaner可以轻松彻底安全地清理系统垃圾文件、注册表垃圾信息和卸载软件一大亮点是CCleaner可。
  • 冬瓜和豆腐一起吃有什么好处(冬瓜和豆腐一起吃的好处介绍)
  • 2024-11-22冬瓜和豆腐一起吃的好处介绍降低血压:冬瓜中含有的钾元素非常丰富,钠元素的含量比较少,而且豆腐中含有的蛋白质丰富,胆固醇含量很低,冬瓜可以有降压的作用,对于有高血压的病人来说有一定的降压的功效和作用降低血脂:冬瓜中所含的膳食纤维。
  • 考驾照不到一年能开车吗(考驾照的时候可以开车吗)
  • 2024-11-22考驾照的时候可以开车吗相信有很多考驾照的小伙伴有同样的一个问题,考驾照可以开车吗?已经考到科目四了这样可不可以去开车?千万不要犯迷糊,考驾照的同时是不可以开车的必须考完驾照才可以上路首先从属性来说,这本身就是无证驾驶交警有。
  • 24个时区所有对应地点(微时区这一站在巴厘岛)
  • 2024-11-22微时区这一站在巴厘岛2018年的计划里本没有巴厘岛某天和小茗同学聊天,没聊几句,她说:“近期一定要去巴厘岛”我说:“那别说近期了,直接订票”一查机票,刚好元旦那几天价格也合理,第二天就把机票订了此次出行有三只:小茗同学、。
  • 罗雀高飞定档时间(罗雀高飞什么时候开播)
  • 2024-11-22罗雀高飞什么时候开播《罗雀高飞》定档时间:2020年7月24日起,在三立台湾台,播出该剧由邱凯伟,大元,田家达等主演《罗雀高飞》,2020年三立台湾台周五台湾好戏系列之第十四部曲2020年4月15日开镜,5月15日正式开。
  • 比亚迪速锐BYD473Q发动机电控系统
  • 2024-11-22比亚迪速锐BYD473Q发动机电控系统进气压力温度传感器一、简图和针脚图1进气压力温度传感器图2进气压力温度传感器电路图图3进气压力温度传感器插头针脚定义:1#接地;2#进气温度信号输出;3#接5V;4#进气压力信号输出二、安装位置这个传。
  • 哈尔滨老大爷打呼噜(哈尔滨70多岁大爷突然胡言乱语)
  • 2024-11-22哈尔滨70多岁大爷突然胡言乱语哈尔滨市的李大爷今年七十多了,为人乐观开朗,脾气温和,平时身体还算不错,偶尔有个小病也不当回事但近一个月来,他时常感到疲惫、头晕,儿女多次劝说他到医院检查一下,他说什么都不去,由于症状越来越严重,家人。
  • 阴阳师最新御魂时间表(阴阳师更新正式服式神御魂无改动)
  • 2024-11-22阴阳师更新正式服式神御魂无改动今天阴阳师例行更新,正式服的大家应该是摩拳擦掌等着开服吧?毕竟超鬼王就要来了呢;而体服的阴阳师应该是等着抽鬼切吧?这么帅气的小伙(老)子(公),人人都想要虽然大致更新内容已经猜到了,但一些特别的活动和。