SpringCloud Sleuth實(shí)現(xiàn)分布式請(qǐng)求鏈路跟蹤流程詳解
1、概念
Git官網(wǎng)地址:https://github.com/spring-cloud/spring-cloud-sleuth
官網(wǎng)地址:https://spring.io/projects/spring-cloud-sleuth
在微服務(wù)框架中,一個(gè)由客戶端發(fā)起的請(qǐng)求在后端系統(tǒng)中會(huì)經(jīng)過多個(gè)不同的的服務(wù)節(jié)點(diǎn)調(diào)用來協(xié)同產(chǎn)生最后的請(qǐng)求結(jié)果,每一個(gè)前段請(qǐng)求都會(huì)形成一條復(fù)雜的分布式服務(wù)調(diào)用鏈路,鏈路中的任何一環(huán)出現(xiàn)高延時(shí)或錯(cuò)誤都會(huì)引起整個(gè)請(qǐng)求最后的失敗。
Spring Cloud Sleuth提供了一套完整的服務(wù)跟蹤的解決方案,在分布式系統(tǒng)中提供追蹤解決方案并且兼容支持了zipkin
2、搭建鏈路監(jiān)控步驟
2.1、zipkin
官方地址:https://zipkin.io/
下載地址:https://gitcode.net/mirrors/openzipkin/zipkin?utm_source=csdn_github_accelerator
通過命令啟動(dòng)
需要定位到當(dāng)前目錄下
java -jar zipkin-server-2.23.18-exec.jar
瀏覽器訪問:http://127.0.0.1:9411/
監(jiān)控流程
一條鏈路通過Trace Id唯一標(biāo)識(shí),Span標(biāo)識(shí)發(fā)起的請(qǐng)求信息,各span通過parent id 關(guān)聯(lián)起來
整個(gè)鏈路的依賴關(guān)系:服務(wù)一 調(diào)用 服務(wù)二 ,服務(wù)二又分別調(diào)用服務(wù)三或四
2.2、服務(wù)提供者
修改cloud-provider-payment8001服務(wù)提供者模塊
1、引入pom.xml依賴
<!--包含了sleuth+zipkin--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zipkin</artifactId> </dependency>
2、添加YAMLA配置文件
spring:
application:
name: cloud-payment-service # 指定程序名稱
zipkin: # 鏈路跟蹤
base-url: http://localhost:9411 # 跟蹤后展示的地址
sleuth:
sampler:
#采樣率值介于 0 到 1 之間,1 則表示全部采集,一般采用0.5
probability: 1
3、業(yè)務(wù)類實(shí)現(xiàn)
在8001PaymentController
控制器上面添加有個(gè)簡單的接口,方便鏈路進(jìn)行跟蹤
/** * 請(qǐng)求鏈路跟蹤測(cè)試 * @return */ @GetMapping("/zipkin") public String paymentZipkin() { return "hi ,i'am paymentzipkin server fall back,welcome to atguigu,O(∩_∩)O哈哈~"; }
4、啟動(dòng)項(xiàng)目
- 啟動(dòng)7001
- 啟動(dòng)8001
2.3、服務(wù)消費(fèi)者(調(diào)用方)
修改cloud-consumer-order80
消費(fèi)者模塊
引入依賴
與提供者一樣
添加YAML配置文件
spring:
application:
name: cloud-order-service # 程序名稱
zipkin: # 鏈路跟蹤
base-url: http://localhost:9411 # 監(jiān)控展示地址
sleuth:
sampler:
probability: 1 # 采樣率
添加控制器
// ====================> zipkin+sleuth /** * 調(diào)用鏈路跟蹤服務(wù)接口 * @return */ @GetMapping("/payment/zipkin") public String paymentZipkin() { String result = restTemplate.getForObject("http://localhost:8001"+"/payment/zipkin/", String.class); return result; }
啟動(dòng)測(cè)試
之前啟動(dòng)了7001、8001
啟動(dòng)當(dāng)前項(xiàng)目80
頁面訪問:http://localhost/consumer/payment/zipkin
多點(diǎn)擊幾次產(chǎn)生鏈路,然后查看鏈路
查看鏈路跟蹤
鏈路詳情
到此這篇關(guān)于SpringCloud Sleuth實(shí)現(xiàn)分布式請(qǐng)求鏈路跟蹤流程詳解的文章就介紹到這了,更多相關(guān)SpringCloud Sleuth內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java循環(huán)終止的實(shí)現(xiàn)方式總結(jié)
循環(huán)是一種重復(fù)執(zhí)行一段代碼的結(jié)構(gòu),Java提供了四種主要的循環(huán)結(jié)構(gòu),本文主要來和大家介紹一下Java循環(huán)終止的實(shí)現(xiàn)方式,有需要的小伙伴可以參考一下2023-10-10Spring Boot 2結(jié)合Spring security + JWT實(shí)現(xiàn)微信小程序登錄
這篇文章主要介紹了Spring Boot 2結(jié)合Spring security + JWT實(shí)現(xiàn)微信小程序登錄,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01spring boot利用docker構(gòu)建gradle項(xiàng)目的實(shí)現(xiàn)步驟
這篇文章主要給大家介紹了關(guān)于spring boot利用docker構(gòu)建gradle項(xiàng)目的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用spring boot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2018-05-05java算法題解LeetCode30包含min函數(shù)的棧實(shí)例
這篇文章主要為大家介紹了java算法題解LeetCode30包含min函數(shù)的棧實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01