Spring Cloud Sleuth 和 Zipkin 进行分布式跟踪使用指南

Spring Cloud Sleuth 和 Zipkin 进行分布式跟踪使用指南

作者:MicroStone 2022-02-18 09:30:48

开发

前端

分布式 分布式跟踪允许您跟踪分布式系统中的请求。本文通过了解如何使用 Spring Cloud Sleuth 和 Zipkin 来做到这一点。

分布式跟踪允许您跟踪分布式系统中的请求。本文通过了解如何使用 Spring Cloud Sleuth 和 Zipkin 来做到这一点。

对于一个做所有事情的大型应用程序(我们通常将其称为单体应用程序),跟踪应用程序内的传入请求很容易。我们可以跟踪日志,然后弄清楚请求是如何处理的。除了应用程序日志本身之外,我们无需查看其他任何内容。

随着时间的推移,单体应用程序变得难以扩展,难以处理大量请求以及随着代码库规模的不断扩大向客户提供新功能。这导致将单体架构分解为微服务,这有助于扩展单个组件并有助于更快地交付。

但并非所有闪耀的都是黄金,对吧?微服务也是如此。我们将整个单体系统拆分为微服务,由一组本地函数调用处理的每个请求现在都被调用一组分布式服务所取代。这样一来,我们就失去了追踪在单体应用中很容易完成的请求之类的事情。现在,要跟踪每个请求,我们必须查看每个服务的日志,并且很难关联。

因此,在分布式系统的情况下,分布式跟踪的概念有助于跟踪请求。

什么是分布式跟踪?

分布式跟踪是一种机制,我们可以使用它跟踪整个分布式系统中的特定请求。它允许我们跟踪请求如何从一个系统进展到另一个系统,从而完成用户的请求。

分布式跟踪的关键概念

分布式跟踪包含两个主要概念:

  • 跟踪 ID
  • 跨度编号

跟踪 id 用于跟踪传入请求并在所有组合服务中跟踪它以满足请求。Span id 跨越服务调用以跟踪接收到的每个请求和发出的响应。

让我们看一下图表。

传入的请求没有任何跟踪 ID。拦截调用的第一个服务会生成跟踪 ID“ID1”及其跨度 ID“A”。span id“B”涵盖了从服务器一的客户端发出请求到服务器二接收、处理并发出响应的时间。

带有 Spring Cloud Sleuth 的 Spring Boot 示例

让我们创建一个集成了 Spring Cloud Sleuth 的应用程序。首先,让我们访问https://start.spring.io/并使用依赖项“Spring Web”和“Spring Cloud Sleuth”创建一个应用程序。

现在让我们创建一个带有两个请求映射的简单控制器。

publicclassController {

privatestaticfinalLoggerlogger=LoggerFactory.getLogger(Controller.class);
privateRestTemplaterestTemplate;

@Value("${spring.application.name}")
privateStringapplicationName;

publicController(RestTemplaterestTemplate) {
this.restTemplate=restTemplate;
}

@GetMapping("/path1")
publicResponseEntitypath1() {

logger.info("Request at {} for request /path1 ", applicationName);
Stringresponse=restTemplate.getForObject("http://localhost:8090/service/path2", String.class);
returnResponseEntity.ok("response from /path1 + "+response);
}

@GetMapping("/path2")
publicResponseEntitypath2(){
logger.info("Request at {} at /path2", applicationName);
returnResponseEntity.ok("response from /path2 ");
}

在这里,我创建了两条路径,Path1调用Path2固定端口 8090。这里的想法是运行同一应用程序的两个单独实例。

现在为了允许侦探将标头注入到传出请求中,我们需要将 RestTemplate 作为 bean 注入,而不是直接初始化它。这将允许侦探向 RestTemplate 添加一个拦截器,以将带有跟踪 id 和跨度 id 的标头注入到传出请求中。

@Bean
publicRestTemplaterestTemplate(RestTemplateBuilderbuilder) {
returnbuilder.build();
}

现在,让我们启动两个实例。为此,首先,构建应用程序,mvn clean verify然后运行以下命令来启动“服务 1”。

java-jar\
target/Distributed-Service-0.0.1-SNAPSHOT.jar\
--spring.application.name=Service-1\
--server.port=8080

然后在不同的终端上运行“服务 2”,如下所示:

java-jar\
target/Distributed-Service-0.0.1-SNAPSHOT.jar\
--spring.application.name=Service-2\
--server.port=8090

应用程序启动后,调用“Service 1”,/path1如下所示:

curl-ihttp://localhost:8080/service/path1

现在让我们看看“服务1”的日志。

INFO [Service-1,222f3b00a283c75c,222f3b00a283c75c] 41114--- [nio-8080-exec-1] c.a.p.distributedservice.Controller      : IncomingrequestatService-1forrequest/path1

日志包含方括号,其中包含三个部分 [Service Name, Trace Id, Span Id]。对于第一个传入的请求,由于没有传入的trace id,span id 与trace id 相同。

查看“服务 2”的日志,我们看到我们为此请求有一个新的 span id。

INFO [Service-2,222f3b00a283c75c,13194db963293a22] 41052--- [nio-8090-exec-1] c.a.p.distributedservice.Controller      : IncomingrequestatService-2at/path2

我截获了从“服务 1”发送到“服务 2”的请求,并发现传出的请求中已经存在以下标头。

x-b3-traceid:"222f3b00a283c75c", 
x-b3-spanid:"13194db963293a22",
x-b3-parentspanid:"222f3b00a283c75c

在这里,我们看到下一个操作(对“服务 2”的调用)的跨度已经注入到标头中。这些是在客户端发出请求时由“服务 1”注入的。这意味着下一次调用“服务 2”的跨度已经从“服务 1”的客户端开始。在上面显示的标题中,“服务 1”的 span id 现在是下一个 span 的父 span id。

为了让事情更容易理解,我们可以使用名为Zipkin的拦截器工具直观地查看跟踪。

使用 Zipkin 可视化跟踪

要将 Zipkin 与应用程序集成,我们需要向应用程序添加 Zipkin 客户端依赖项。

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

添加此依赖项后,Zipkin 客户端默认将跟踪发送到 Zipkin 服务器的 9411 端口。让我们使用其 docker 映像启动 Zipkin 服务器。我为此创建了一个简单的 docker-compose 文件。

version: "3.1"
services:
zipkin:
image: openzipkin/zipkin:2
ports:
-"9411:9411"

我们现在可以使用docker-compose up命令启动服务器。然后,您可以在以下位置访问 UIhttp://localhost:9411/

由于我们使用的是默认端口,我们不需要指定任何属性,但是如果您打算使用不同的端口,则需要添加以下属性。

spring:
zipkin:
baseUrl: http://localhost:9411

完成后,让我们使用上面相同的命令启动两个应用程序。在向路径中的“服务 1”发出请求时,/path1我们会得到以下跟踪。

这里显示了两个服务的跨度。我们可以通过查看跨度来更深入地挖掘。

“服务 1”的跨度是一个正常的跨度,涵盖了它接收到返回响应的请求。有趣的是第二个跨度。

在此,跨度中有四个点。

  • 第一点是指来自“服务1”的客户端何时开始请求。
  • 第二点是“服务 2”开始处理请求的时间。
  • 第三点是“Server 1”上的客户端完成接收响应的时间。
  • 最后,“服务器 2”完成的最后一点。

因此,我们了解了如何将分布式跟踪与 Spring Cloud Sleuth 集成,并使用 Zipkin 可视化跟踪。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/308702.html<

(0)
运维的头像运维
上一篇2025-05-27 17:13
下一篇 2025-05-27 17:14

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注