SpringBoot中的分布式追蹤及使用詳解
SpringBoot中的分布式追蹤及使用
分布式追蹤的概念
分布式追蹤(Distributed Tracing)是一種用于追蹤分布式系統(tǒng)中請(qǐng)求的執(zhí)行路徑和時(shí)間的技術(shù)。在分布式系統(tǒng)中,由于請(qǐng)求可能會(huì)經(jīng)過多個(gè)服務(wù)節(jié)點(diǎn),因此需要在請(qǐng)求流程中添加唯一的標(biāo)識(shí)符(Trace ID),并將 Trace ID 傳遞給所有相關(guān)的服務(wù)節(jié)點(diǎn)。每個(gè)服務(wù)節(jié)點(diǎn)在處理請(qǐng)求時(shí),都需要將 Trace ID 記錄在請(qǐng)求的上下文中,并將請(qǐng)求的上下文信息傳遞給下一個(gè)服務(wù)節(jié)點(diǎn)。這樣,就可以通過 Trace ID 來追蹤一個(gè)請(qǐng)求在整個(gè)系統(tǒng)中的執(zhí)行路徑和時(shí)間。在追蹤過程中,還需要記錄每個(gè)服務(wù)節(jié)點(diǎn)處理請(qǐng)求的時(shí)間和耗時(shí),以便分析和優(yōu)化系統(tǒng)性能。
Spring Cloud Sleuth
Spring Cloud Sleuth 是 Spring Cloud 中的一個(gè)分布式追蹤框架,它提供了基于 Trace ID 的請(qǐng)求追蹤功能,可以協(xié)助開發(fā)人員快速追蹤分布式系統(tǒng)中的請(qǐng)求執(zhí)行路徑和時(shí)間,并幫助排查問題和優(yōu)化性能。
Spring Cloud Sleuth 使用 Zipkin 來存儲(chǔ)和展示分布式追蹤信息,Zipkin 是一個(gè)開源的分布式追蹤系統(tǒng),可以用于存儲(chǔ)和展示分布式系統(tǒng)中的請(qǐng)求追蹤信息。
Spring Boot 中的分布式追蹤
Spring Boot 集成了 Spring Cloud Sleuth,可以非常方便地實(shí)現(xiàn)分布式追蹤功能。在 Spring Boot 應(yīng)用程序中,只需要添加以下依賴:
<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 應(yīng)用程序就可以自動(dòng)配置分布式追蹤功能,并將追蹤信息發(fā)送到 Zipkin 服務(wù)器。
在應(yīng)用程序中,可以通過 Tracer
接口來創(chuàng)建 Trace ID,并將 Trace ID 記錄在請(qǐng)求的上下文中:
@Autowired private Tracer tracer; @GetMapping("/hello") public String hello() { Span span = tracer.nextSpan().name("hello").start(); try (Tracer.SpanInScope ws = tracer.withSpan(span)) { // 處理請(qǐng)求 return "Hello World!"; } finally { span.finish(); } }
在每個(gè)服務(wù)節(jié)點(diǎn)中,都需要將 Trace ID 記錄在請(qǐng)求的上下文中,并將請(qǐng)求的上下文信息傳遞給下一個(gè)服務(wù)節(jié)點(diǎn)。Spring Boot 可以通過 RestTemplate 和 Feign 來自動(dòng)傳遞請(qǐng)求的上下文信息,只需要在 RestTemplate 和 Feign 中添加相應(yīng)的配置即可:
@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 是一個(gè)用于存儲(chǔ)和展示分布式追蹤信息的系統(tǒng),可以用于分析和優(yōu)化分布式系統(tǒng)的性能。在 Spring Boot 中,可以通過以下步驟來使用 Zipkin:
- 下載并啟動(dòng) Zipkin 服務(wù)器
可以從 Zipkin 的官網(wǎng)下載 Zipkin 服務(wù)器,并啟動(dòng) Zipkin 服務(wù)器。啟動(dòng) Zipkin 服務(wù)器后,可以在瀏覽器中訪問 http://localhost:9411
來查看 Zipkin 的 Web 界面。
- 配置 Spring Boot 應(yīng)用程序發(fā)送追蹤信息到 Zipkin 服務(wù)器
在 Spring Boot 應(yīng)用程序中,可以通過以下配置來將追蹤信息發(fā)送到 Zipkin 服務(wù)器:
spring: zipkin: base-url: http://localhost:9411
- 查看分布式追蹤信息
在啟動(dòng) Spring Boot 應(yīng)用程序后,可以通過訪問應(yīng)用程序的端點(diǎn)來觸發(fā)請(qǐng)求,并在 Zipkin 的 Web 界面中查看分布式追蹤信息。在 Zipkin 的 Web 界面中,可以查看每個(gè)請(qǐng)求的 Trace ID、請(qǐng)求流程中的服務(wù)節(jié)點(diǎn)、服務(wù)節(jié)點(diǎn)的執(zhí)行時(shí)間和耗時(shí)等信息。
總結(jié)
分布式追蹤技術(shù)是解決分布式系統(tǒng)中請(qǐng)求執(zhí)行路徑和時(shí)間無法追蹤的問題的關(guān)鍵技術(shù)之一。Spring Boot 集成了 Spring Cloud Sleuth 和 Zipkin,使得分布式追蹤變得非常簡(jiǎn)單。在 Spring Boot 應(yīng)用程序中,可以通過添加相應(yīng)的依賴和配置來實(shí)現(xiàn)分布式追蹤功能,并將追蹤信息發(fā)送到 Zipkin 服務(wù)器。使用分布式追蹤技術(shù)可以幫助開發(fā)人員更好地管理和監(jiān)控分布式系統(tǒng),并提高系統(tǒng)的可靠性和性能。
以上就是SpringBoot中的分布式追蹤及使用詳解的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot分布式追蹤的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
雙Token無感刷新機(jī)制實(shí)現(xiàn)方式
本文介紹了如何在Vue.js前端和Java后端實(shí)現(xiàn)雙Token的無感刷新機(jī)制,后端通過Jwt過濾器解析Token,前端在請(qǐng)求時(shí)攜帶Token并保存,當(dāng)Token過期時(shí),前端會(huì)自動(dòng)刷新并重新發(fā)送請(qǐng)求,實(shí)現(xiàn)無感刷新2025-03-03SpringBoot項(xiàng)目啟動(dòng)錯(cuò)誤:找不到或無法加載主類的三種解決方法
在開發(fā)SpringBoot應(yīng)用時(shí),經(jīng)??赡軙?huì)遇到一個(gè)啟動(dòng)錯(cuò)誤:“錯(cuò)誤:找不到或無法加載主類 com.example.controller.demo.DemoApplication”,本文將介紹三種解決這一問題的方法,需要的朋友可以參考下2024-10-10SpringBoot與Quartz集成實(shí)現(xiàn)分布式定時(shí)任務(wù)集群的代碼實(shí)例
今天小編就為大家分享一篇關(guān)于SpringBoot與Quartz集成實(shí)現(xiàn)分布式定時(shí)任務(wù)集群的代碼實(shí)例,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-03-03Mybatis?Plus分頁(yè)查詢返回total為0問題解決
在使用MybatisPlus進(jìn)行分頁(yè)查詢時(shí),可能會(huì)遇到返回的總條數(shù)(total)為0的問題,這通常是由于未配置MybatisPlus的分頁(yè)插件攔截器導(dǎo)致的,本文就來介紹一下解決方法,感興趣的可以了解一下2024-10-10java.lang.NoClassDefFoundError錯(cuò)誤的原因及解決方法
這篇文章主要給大家介紹了關(guān)于java.lang.NoClassDefFoundError錯(cuò)誤的原因及解決的相關(guān)資料,java.lang.NoClassDefFoundError是Java虛擬機(jī)在運(yùn)行時(shí)無法找到特定類的錯(cuò)誤,需要的朋友可以參考下2023-10-10Java ScheduledExecutorService的具體使用
ScheduledExecutorService有線程池的特性,也可以實(shí)現(xiàn)任務(wù)循環(huán)執(zhí)行,本文主要介紹了Java ScheduledExecutorService的具體使用,具有一定的參考價(jià)值,感興趣的可以了解一下2023-05-05Java基礎(chǔ)知識(shí)之StringReader流的使用
這篇文章主要介紹了Java基礎(chǔ)知識(shí)之StringReader流的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12