Spring Boot 中的分布式追踪及使用

Spring Boot 中的分布式追踪及使用

随着互联网应用程序的复杂性不断增加,分布式系统已经成为了许多企业级应用程序的标配。在分布式系统中,由于服务之间的调用关系错综复杂,很难追踪到一个请求在整个系统中的执行路径和时间,这就给排查问题和性能优化带来了巨大的挑战。为了解决这个问题,分布式追踪技术应运而生。本文将介绍 Spring Boot 中的分布式追踪技术及其使用方法。

在这里插入图片描述

分布式追踪的概念

分布式追踪(Distributed Tracing)是一种用于追踪分布式系统中请求的执行路径和时间的技术。在分布式系统中,由于请求可能会经过多个服务节点,因此需要在请求流程中添加唯一的标识符(Trace ID),并将 Trace ID 传递给所有相关的服务节点。每个服务节点在处理请求时,都需要将 Trace ID 记录在请求的上下文中,并将请求的上下文信息传递给下一个服务节点。这样,就可以通过 Trace ID 来追踪一个请求在整个系统中的执行路径和时间。在追踪过程中,还需要记录每个服务节点处理请求的时间和耗时,以便分析和优化系统性能。

Spring Cloud Sleuth

Spring Cloud Sleuth 是 Spring Cloud 中的一个分布式追踪框架,它提供了基于 Trace ID 的请求追踪功能,可以协助开发人员快速追踪分布式系统中的请求执行路径和时间,并帮助排查问题和优化性能。

Spring Cloud Sleuth 使用 Zipkin 来存储和展示分布式追踪信息,Zipkin 是一个开源的分布式追踪系统,可以用于存储和展示分布式系统中的请求追踪信息。

Spring Boot 中的分布式追踪

Spring Boot 集成了 Spring Cloud Sleuth,可以非常方便地实现分布式追踪功能。在 Spring Boot 应用程序中,只需要添加以下依赖:

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

添加这些依赖后,Spring Boot 应用程序就可以自动配置分布式追踪功能,并将追踪信息发送到 Zipkin 服务器。

在应用程序中,可以通过 Tracer 接口来创建 Trace ID,并将 Trace ID 记录在请求的上下文中:

@Autowired
private Tracer tracer;@GetMapping("/hello")
public String hello() {Span span = tracer.nextSpan().name("hello").start();try (Tracer.SpanInScope ws = tracer.withSpan(span)) {// 处理请求return "Hello World!";} finally {span.finish();}
}

在每个服务节点中,都需要将 Trace ID 记录在请求的上下文中,并将请求的上下文信息传递给下一个服务节点。Spring Boot 可以通过 RestTemplateFeign 来自动传递请求的上下文信息,只需要在 RestTemplateFeign 中添加相应的配置即可:

@Bean
public RestTemplate restTemplate() {return new RestTemplateBuilder().interceptors(new TraceRestTemplateInterceptor(tracer())).build();
}@Bean
public Feign.Builder feignBuilder() {return Feign.builder().requestInterceptor(new TraceFeignRequestInterceptor(tracer()));
}

Zipkin 的使用

Zipkin 是一个用于存储和展示分布式追踪信息的系统,可以用于分析和优化分布式系统的性能。在 Spring Boot 中,可以通过以下步骤来使用 Zipkin:

  1. 下载并启动 Zipkin 服务器

可以从 Zipkin 的官网下载 Zipkin 服务器,并启动 Zipkin 服务器。启动 Zipkin 服务器后,可以在浏览器中访问 http://localhost:9411 来查看 Zipkin 的 Web 界面。

  1. 配置 Spring Boot 应用程序发送追踪信息到 Zipkin 服务器

在 Spring Boot 应用程序中,可以通过以下配置来将追踪信息发送到 Zipkin 服务器:

spring:zipkin:base-url: http://localhost:9411
  1. 查看分布式追踪信息

在启动 Spring Boot 应用程序后,可以通过访问应用程序的端点来触发请求,并在 Zipkin 的 Web 界面中查看分布式追踪信息。在 Zipkin 的 Web 界面中,可以查看每个请求的 Trace ID、请求流程中的服务节点、服务节点的执行时间和耗时等信息。

总结

分布式追踪技术是解决分布式系统中请求执行路径和时间无法追踪的问题的关键技术之一。Spring Boot 集成了 Spring Cloud Sleuth 和 Zipkin,使得分布式追踪变得非常简单。在 Spring Boot 应用程序中,可以通过添加相应的依赖和配置来实现分布式追踪功能,并将追踪信息发送到 Zipkin 服务器。使用分布式追踪技术可以帮助开发人员更好地管理和监控分布式系统,并提高系统的可靠性和性能。

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

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

相关文章

智安网络|新型恶意软件攻击:持续威胁网络安全

当今数字化时代&#xff0c;恶意软件已经成为网络安全领域中的一项巨大威胁。随着技术的不断进步&#xff0c;恶意软件的攻击方式也在不断演变和发展。 以下是一些目前比较常见的新型恶意软件攻击&#xff1a; **1.勒索软件&#xff1a;**勒索软件是一种恶意软件&#xff0c;它…

【数据分析 - 基础入门之NumPy⑤】NumPy基本操作 - 二

知识目录 前言一、聚合函数二、矩阵操作2.1 算术运算2.2 线性代数2.3 其他数学操作 三、广播机制3.1 广播的原则3.2 案例 四、排序五、文件操作结语相关导读 前言 大家好&#xff01;本期给大家带来的是【数据分析 - 基础入门之NumPy⑤】NumPy基本操作 - 二&#xff0c;收录于…

【Ubuntu】系统U盘变为普通U盘

如果您在 Ubuntu 系统上没有磁盘工具可用&#xff0c;您可以尝试使用命令行工具来格式化系统 U 盘。请按照以下步骤进行操作&#xff1a; 打开终端&#xff1a;在 Ubuntu 桌面上&#xff0c;按下 Ctrl Alt T 快捷键&#xff0c;或者在应用程序菜单中搜索并打开 "终端&qu…

《MySQL》数据类型

文章目录 一&#xff0c;数值类型int类型bit类型小数类型float 和 decimal 二&#xff0c;字符串类型char和varchar日期和时间类型enum和set 一&#xff0c;数值类型 MySQL数据库里面的数据类型 int类型 int类型是一个大类 类型大小tinyint1字节 &#xff08;-27 ~ 27-1&a…

JS 实现CSV文件转换SQL文件小工具

一. 需求 最近在项目中遇到一个问题&#xff0c;客户提供的数据是CSV格式的&#xff0c; 需要将CSV文件中的数据转换为SQL语句文件。 &#x1f605;由于本人不会Excel的vba编程&#xff0c;因此决定使用JS来实现。 二. 实现思路 提供一个文件上传框&#xff0c;支持多文件上…

并发编程_jmm部分

1. JMM 理解 前提&#xff1a;并发编程有3大问题&#xff0c;可见性、有序性、原子性。 导致可见性的原因是缓存&#xff0c;有序性的原因是 编译器优化。解决方法就是直接禁用缓存和编译器优化&#xff0c;导致程序性能堪忧。 因此合理的方案就是按需禁用缓存和编译器优化。 …

ATFX国际:大非农数据来袭,美国劳动力市场需求或空前旺盛

ATFX国际&#xff1a;昨日晚间公布的ADP数据震惊市场&#xff0c;新增就业人口高达49.7万人&#xff0c;而预期值仅为22.8万人&#xff0c;前值也只有26.7万人。公布值约为预期值和前值的总和。 ▲ATFX图 ADP数据是非农就业报告的前瞻指标&#xff0c;前者表现亮眼&#xff0c…

【算法集训之线性表篇】Day 01

文章目录 题目知识点补充思路分析代码实现运行结果 题目 01.从顺序表中删除具有最小值元素&#xff08;假设唯一&#xff09;并返回被删元素的值。空出位置由最后一个元素填补&#xff0c;若顺序表为空&#xff0c;则显示出错信息并退出运行。 知识点补充 顺序表的特点是逻辑…

Handshake failed due to invalid Upgrade header: null 解决方案以及连接60s,信息不交互,连接断开

Handshake failed due to invalid Upgrade header: null 解决方案以及连接60s&#xff0c;信息不交互&#xff0c;连接断开 1. 问题背景&#xff1a;因为后端用了nginx代理&#xff0c;所以websocket连接的过程中报错&#xff1a;Handshake failed due to invalid Upgrade hea…

Elasticsearch:跨集群复制应用场景及实操 - Cross Cluster Replication

通过跨集群复制&#xff08;Cross Cluster Replication - CCR&#xff09;&#xff0c;你可以跨集群将索引复制并实现&#xff1a; 在数据中心中断时继续处理搜索请求防止搜索量影响索引吞吐量通过在距用户较近的地理位置处理搜索请求来减少搜索延迟 跨集群复制采用主动 - 被…

HTML5+CSS3+JS小实例:背景动态变化的登录界面2.0

实例:背景动态变化的登录界面2.0 技术栈:HTML+CSS+JS 效果: 源码: 【html】 <!DOCTYPE html> <html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"><meta name="viewport" con…

Chapter 4: Functions | Python for Everybody 讲义笔记_En

文章目录 Python for Everybody课程简介FunctionsFunction callsBuilt-in functionsType conversion functionsMath functionsRandom numbersAdding new functionsDefinitions and usesFlow of executionParameters and argumentsFruitful functions and void functionsWhy fun…