如何在 Spring Boot 中进行分布式追踪

在 Spring Boot 中进行分布式追踪

分布式系统中的应用程序由多个微服务组成,它们可以位于不同的服务器、容器或云中。当出现问题时,如性能瓶颈、错误或延迟,了解问题的根本原因变得至关重要。分布式追踪是一种用于跟踪和分析分布式应用程序性能和行为的工具。本文将介绍如何在Spring Boot应用程序中进行分布式追踪,以及如何使用Spring Cloud Sleuth和Zipkin来实现这一目标。

在这里插入图片描述

什么是分布式追踪?

分布式追踪是一种监视分布式系统的方法,通过追踪和分析请求在不同服务之间的传递路径和时间来帮助诊断性能问题。分布式追踪通常包括以下主要组件:

  • 跟踪器(Tracer):用于在请求进入和离开应用程序时创建唯一的跟踪标识符,并记录事件和时间戳。

  • 跟踪(Trace):代表一次请求的完整生命周期,包括多个服务和操作。

  • 跨度(Span):代表一次操作或事件,跨度通常包含有关操作的信息,如名称、持续时间和标签。

  • 采样(Sampling):用于确定哪些请求应该记录并进行跟踪,以防止数据过于庞大。

使用 Spring Cloud Sleuth 进行分布式追踪

Spring Cloud Sleuth是Spring Cloud的一部分,它提供了在Spring Boot应用程序中进行分布式追踪的支持。Spring Cloud Sleuth集成了Zipkin,一个开源的分布式追踪系统,用于收集、存储和查询跟踪数据。以下是如何在Spring Boot应用程序中使用Spring Cloud Sleuth的步骤:

步骤1:添加依赖项

在您的Spring Boot项目的pom.xml文件中添加Spring Cloud Sleuth的依赖项:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-sleuth</artifactId>
</dependency>

步骤2:配置应用程序名称

您可以配置应用程序的名称,以便在分布式追踪中标识不同的应用程序。在application.propertiesapplication.yml文件中添加以下配置:

spring.application.name=my-service

步骤3:启动 Zipkin 服务器

要使用Spring Cloud Sleuth,您需要启动一个Zipkin服务器。您可以使用Docker、Java应用程序或其他方法来启动Zipkin服务器。以下是使用Docker启动Zipkin服务器的示例命令:

docker run -d -p 9411:9411 openzipkin/zipkin

步骤4:运行应用程序

运行您的Spring Boot应用程序。Spring Cloud Sleuth将自动为每个请求创建唯一的跟踪标识符,并记录相关的跟踪和跨度。

步骤5:查看追踪数据

打开浏览器并访问Zipkin服务器的Web界面(默认端口9411)。您将能够查看和分析应用程序的分布式追踪数据。

使用 Spring Cloud Sleuth 进行手动追踪

除了自动追踪外,Spring Cloud Sleuth还允许您手动创建和记录跟踪数据。这对于记录自定义事件或特定操作非常有用。以下是一个示例代码,演示如何在Spring Boot应用程序中手动创建跟踪:

import org.springframework.cloud.sleuth.annotation.NewSpan;
import org.springframework.stereotype.Service;@Service
public class MyService {@NewSpan("custom-span-name")public void performCustomOperation() {// 在这里执行自定义操作}
}

在上述示例中,我们使用@NewSpan注解来创建一个新的跨度,您可以为跨度指定名称。然后,您可以在performCustomOperation方法中执行自定义操作,该操作将被记录到分布式追踪中。

使用 Sleuth 的 Trace 和 Span

在代码中,您可以通过 TracerSpan 来访问当前跟踪和跨度信息。以下是更多关于如何使用 TracerSpan 的示例代码,演示了它们的一些常见用法:

import org.springframework.cloud.sleuth.Tracer;
import org.springframework.cloud.sleuth.annotation.NewSpan;
import org.springframework.stereotype.Service;@Service
public class MyService {private final Tracer tracer;public MyService(Tracer tracer) {this.tracer = tracer;}@NewSpan("custom-span-name")public void performCustomOperation() {// 访问当前跨度Span currentSpan = tracer.currentSpan();// 访问当前跟踪Trace currentTrace = tracer.currentTrace();// 创建一个自定义的子跨度Span customSpan = tracer.nextSpan().name("custom-subspan").start();try {// 在子跨度内执行操作// ...// 设置子跨度的标签customSpan.tag("custom-tag", "tag-value");} finally {// 完成子跨度customSpan.finish();}}
}

在上述示例中,我们注入了 Tracer 对象,它允许我们访问当前跟踪和跨度。我们还创建了一个自定义的子跨度,并在其中执行操作。最后,我们通过调用 finish() 方法来完成子跨度。您可以为跨度设置标签以添加有关操作的额外信息。

高级配置和自定义

Spring Cloud Sleuth 提供了丰富的配置选项和自定义功能,以适应不同的追踪需求。您可以配置要记录的采样率、设置追踪信息的导出方式,甚至将追踪数据发送到不同的追踪系统。

以下是一些高级配置示例:

配置采样率

您可以配置采样率以决定哪些请求应该记录和追踪。以下是一个示例配置,将采样率设置为50%:

spring.sleuth.sampler.probability=0.5

自定义导出

如果您想将追踪数据导出到不同的追踪系统,例如Jaeger或AWS X-Ray,您可以配置自定义的 SpanReporter。这需要一些额外的编程工作,但允许您集成其他追踪工具。

配置 Zipkin

如果您希望将追踪数据发送到 Zipkin 服务器之外的其他地方,您可以配置 Zipkin 发送器的类型。以下是一个示例配置,将追踪数据发送到自定义的远程服务器:

spring.zipkin.sender.type=web
spring.zipkin.base-url=http://custom-zipkin-server:9411/

结论

在分布式系统中进行追踪是确保应用程序性能和可用性的重要组成部分。Spring Cloud Sleuth 提供了一种方便而强大的方式来实现分布式追踪,它集成了 Zipkin,使您能够轻松查看和分析跟踪数据。通过使用 Spring Cloud Sleuth,您可以更好地了解应用程序的行为,快速诊断性能问题,并提高系统的可维护性。

本文介绍了如何在 Spring Boot 应用程序中集成 Spring Cloud Sleuth,并使用自动追踪、手动追踪、Trace 和 Span 来记录和分析分布式应用程序的性能数据。希望这篇文章对您有所帮助,让您更好地理解如何在 Spring Boot 应用程序中进行分布式追踪。通过使用 Spring Cloud Sleuth,您可以建立一个更可观察和可管理的分布式系统,提供更好的用户体验。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/153405.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【数据库——MySQL】(14)过程式对象程序设计——游标、触发器

目录 1. 游标1.1 声明游标1.2 打开游标1.3 读取游标1.4 关闭游标1.5 游标示例 2. 触发器2.1 创建触发器2.2 修改触发器2.3 删除触发器2.4 触发器类型2.5 触发器示例 参考书籍 1. 游标 游标一般和存储过程一起配合使用。 1.1 声明游标 要使用游标&#xff0c;需要用到 DECLAR…

java Spring Boot整合jwt实现token生成

先在 pom.xml 文件中注入依赖 <!-- JWT --> <dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-api</artifactId><version>0.11.2</version> </dependency> <dependency><groupId>io.jsonw…

ctfshow-web12(glob绕过)

打开链接&#xff0c;在网页源码里找到提示 要求以get请求方式给cmd传入参数 尝试直接调用系统命令&#xff0c;没有回显&#xff0c;可能被过滤了 测试phpinfo&#xff0c;回显成功&#xff0c;确实存在了代码执行 接下来我们尝试读取一下它存在的文件&#xff0c;这里主要介…

JavaScript中的深拷贝(deep copy)和浅拷贝(shallow copy)

聚沙成塔每天进步一点点 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是完全的新手还是有一些基础的开发…

5MW风电永磁直驱发电机-1200V直流并网Simulink仿真模型

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

浅析森林烟火AI检测算法的应用及场景使用说明

一、方案背景 现有的森林防火监测系统落后&#xff0c;以人工地面巡护、瞭望塔高点巡查为主&#xff0c;存在巡护范围有限、巡护效率低等问题&#xff0c;建立健全的森林防火风险预警体系&#xff0c;实现对森林、林场等场景的全天候智能自动监测、火情预警&#xff0c;及时发…

如何通过三行配置解决在Kubernetes中的gRPC扩展问题

一切都始于我向我们的高级软件工程师提出的一个问题&#xff1a; “忘掉通信速度。你真的觉得在gRPC中开发通信比REST更好吗&#xff1f;” 我不想听到的答案立刻就来了&#xff1a;“绝对是的。” 在我提出这个问题之前&#xff0c;我一直在监控我们的服务在滚动更新和扩展Po…

lua学习笔记

单行注释&#xff1a; 多行注释&#xff1a; 命名&#xff1a; Lua不支持下划线大写字母&#xff0c;比如&#xff1a;_ABC 但支持&#xff1a;_abc 关键字&#xff1a; 全局变量&#xff1a; 直接变量名 内容就是全局 局部变量&#xff1a; 加上local即可 nil&#xff1…

服务器上部署python脚本

1.查看服务器上的python是否自带&#xff0c;一般都自带 2.将本地脚本上传到服务器 3.直接运行一下脚本看报什么错误 代码错误&#xff0c; 将f删除后报别的错误 上面是未安装依赖的错误。我们安装一下依赖 下面是编码的解决 #!/usr/bin/python # -*- coding: utf-8 -*- 先把…

查找算法——二分查找法

一、介绍 首先需要将查找的数据排好序&#xff0c;再进行二分查找法来进行查找&#xff0c;二分查找是将数据范围不断分割为两份&#xff0c;不断比较中间值与待查找值的大小来确定其在哪个区间范围的一种方法。例如&#xff1a;在一组数据&#xff08;1&#xff0c;4&#xff…

只会 Windows 也能轻松搭建远程桌面 RustDesk 自用服务器

网管小贾 / sysadm.cc “哥&#xff0c;你啥时候回来啊&#xff1f;XX业务系统又出问题了&#xff01;” “情况紧急&#xff0c;老大说让你远程处理&#xff0c;总之尽快解决&#xff01;” 虽说我常年出差在外总能收到这样的消息&#xff0c;似乎早已习惯&#xff0c;但是公…

分类预测 | MATLAB实现KOA-CNN-LSTM开普勒算法优化卷积长短期记忆神经网络数据分类预测

分类预测 | MATLAB实现KOA-CNN-LSTM开普勒算法优化卷积长短期记忆神经网络数据分类预测 目录 分类预测 | MATLAB实现KOA-CNN-LSTM开普勒算法优化卷积长短期记忆神经网络数据分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 1.MATLAB实现KOA-CNN-LSTM开普勒算法优化…

精品Python语言django基于爬虫的新闻资讯分析系统的设计与实现

《[含文档PPT源码等]精品Python项目django基于爬虫的新闻资讯分析系统的设计与实现》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程等&#xff01; 软件开发环境及开发工具&#xff1a; 开发语言&#xff1a;python 使用框架&#xff1a;Django 前…

代码理解技术应用实践介绍

作者 | CQT&星云团队 一、前言 代码理解作为软件知识图谱重要的技术之一&#xff0c;可以为构建、测试、定位、代码解释等提供基础的技术和数据保障&#xff0c;也是持续集成的起点&#xff0c;只有理解了代码才能有目的性的进行有效构建。代码理解对于软件开发的成功和维…

Linux 部署 MinIO 分布式对象存储 配置为 typora 图床

前言 MinIO 是一款高性能的对象存储系统&#xff0c;它可以用于大规模的 AI/ML、数据湖和数据库工作负载。它的 API 与Amazon S3 云存储服务完全兼容&#xff0c;可以在任何云或本地基础设施上运行。MinIO 是开源软件&#xff0c;也提供商业许可和支持 MinIO 的特点有&#x…

WPS/word 表格跨行如何续表、和表的名称

1&#xff1a;具体操作&#xff1a; 将光标定位在跨页部分的第一行任意位置&#xff0c;按下快捷键ctrlshiftenter&#xff0c;就可以在跨页的表格上方插入空行&#xff08;在空行可以写&#xff0c;表1-3 xxxx&#xff08;续&#xff09;&#xff09; 在空行中输入…

vue cli和vite区别

1.Vue CLI脚手架 什么是Vue脚手架&#xff1f; 在真实开发中我们不可能每一个项目从头来完成所有的webpack配置&#xff0c;这样显示开发的效率会大大的降低&#xff1b;所以在真实开发中&#xff0c;我们通常会使用脚手架来创建一个项目&#xff0c;Vue的项目我们使用的就是…

苍穹外卖项目

1. 苍穹外卖项目介绍 1.1 项目介绍 定位&#xff1a;专门为餐饮企业&#xff08;餐厅、饭店&#xff09;定制的一款软件产品 项目架构&#xff1a;体现项目中的业务功能模块 1.2 产品原型 产品原型&#xff1a;用于展示项目的业务功能&#xff0c;一般由产品经理进行设计 …

安全与隐私:直播购物App开发中的重要考虑因素

随着直播购物App的崭露头角&#xff0c;开发者需要特别关注安全性和隐私问题。本文将介绍在直播购物App开发中的一些重要安全和隐私考虑因素&#xff0c;并提供相关的代码示例。 1. 数据加密 在直播购物App中&#xff0c;用户的个人信息和支付信息是极为敏感的数据。为了保护…

忘记压缩包密码?解决方法一键找回,省时又便捷!

使用在线rar/zip解密工具&#xff0c;找回rar/zip密码并解密压缩包的方法非常简单。具体步骤如下&#xff1a;首先&#xff0c;在百度上搜索“密码帝官网”&#xff0c;这是一个专业的解密服务网站。然后&#xff0c;点击搜索结果中的链接&#xff0c;进入官网首页。在页面上方…