激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - Java教程 - 淺談Spring-cloud 之 sleuth 服務(wù)鏈路跟蹤

淺談Spring-cloud 之 sleuth 服務(wù)鏈路跟蹤

2021-03-15 12:04方志朋 Java教程

本篇文章主要介紹了淺談Spring-cloud 之 sleuth 服務(wù)鏈路跟蹤,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

這篇文章主要講述服務(wù)追蹤組件zipkin,spring cloud sleuth集成了zipkin組件。

一、簡(jiǎn)介

add sleuth to the classpath of a spring boot application (see below for maven and gradle examples), and you will see the correlation data being collected in logs, as long as you are logging requests.

—— 摘自官網(wǎng)

spring cloud sleuth 主要功能就是在分布式系統(tǒng)中提供追蹤解決方案,并且兼容支持了 zipkin,你只需要在pom文件中引入相應(yīng)的依賴即可。

二、服務(wù)追蹤分析

微服務(wù)架構(gòu)上通過(guò)業(yè)務(wù)來(lái)劃分服務(wù)的,通過(guò)rest調(diào)用,對(duì)外暴露的一個(gè)接口,可能需要很多個(gè)服務(wù)協(xié)同才能完成這個(gè)接口功能,如果鏈路上任何一個(gè)服務(wù)出現(xiàn)問(wèn)題或者網(wǎng)絡(luò)超時(shí),都會(huì)形成導(dǎo)致接口調(diào)用失敗。隨著業(yè)務(wù)的不斷擴(kuò)張,服務(wù)之間互相調(diào)用會(huì)越來(lái)越復(fù)雜。

淺談Spring-cloud 之 sleuth 服務(wù)鏈路跟蹤

隨著服務(wù)的越來(lái)越多,對(duì)調(diào)用鏈的分析會(huì)越來(lái)越復(fù)雜。它們之間的調(diào)用關(guān)系也許如下:

淺談Spring-cloud 之 sleuth 服務(wù)鏈路跟蹤

三、術(shù)語(yǔ)

span:基本工作單元,例如,在一個(gè)新建的span中發(fā)送一個(gè)rpc等同于發(fā)送一個(gè)回應(yīng)請(qǐng)求給rpc,span通過(guò)一個(gè)64位id唯一標(biāo)識(shí),trace以另一個(gè)64位id表示,span還有其他數(shù)據(jù)信息,比如摘要、時(shí)間戳事件、關(guān)鍵值注釋(tags)、span的id、以及進(jìn)度id(通常是ip地址)

span在不斷的啟動(dòng)和停止,同時(shí)記錄了時(shí)間信息,當(dāng)你創(chuàng)建了一個(gè)span,你必須在未來(lái)的某個(gè)時(shí)刻停止它。

trace:一系列spans組成的一個(gè)樹(shù)狀結(jié)構(gòu),例如,如果你正在跑一個(gè)分布式大數(shù)據(jù)工程,你可能需要?jiǎng)?chuàng)建一個(gè)trace。

annotation:用來(lái)及時(shí)記錄一個(gè)事件的存在,一些核心annotations用來(lái)定義一個(gè)請(qǐng)求的開(kāi)始和結(jié)束

  1. cs - client sent -客戶端發(fā)起一個(gè)請(qǐng)求,這個(gè)annotion描述了這個(gè)span的開(kāi)始
  2. sr - server received -服務(wù)端獲得請(qǐng)求并準(zhǔn)備開(kāi)始處理它,如果將其sr減去cs時(shí)間戳便可得到網(wǎng)絡(luò)延遲
  3. ss - server sent -注解表明請(qǐng)求處理的完成(當(dāng)請(qǐng)求返回客戶端),如果ss減去sr時(shí)間戳便可得到服務(wù)端需要的處理請(qǐng)求時(shí)間
  4. cr - client received -表明span的結(jié)束,客戶端成功接收到服務(wù)端的回復(fù),如果cr減去cs時(shí)間戳便可得到客戶端從服務(wù)端獲取回復(fù)的所有所需時(shí)間

將span和trace在一個(gè)系統(tǒng)中使用zipkin注解的過(guò)程圖形化:

淺談Spring-cloud 之 sleuth 服務(wù)鏈路跟蹤

四、構(gòu)建工程

基本知識(shí)講解完畢,下面我們來(lái)實(shí)戰(zhàn),本文的案例主要有三個(gè)工程組成:一個(gè)server-zipkin,它的主要作用使用zipkinserver 的功能,收集調(diào)用數(shù)據(jù),并展示;一個(gè)service-hi,對(duì)外暴露hi接口;一個(gè)service-miya,對(duì)外暴露miya接口;這兩個(gè)service可以相互調(diào)用;并且只有調(diào)用了,server-zipkin才會(huì)收集數(shù)據(jù)的,這就是為什么叫服務(wù)追蹤了。

4.1 構(gòu)建server-zipkin

建一個(gè)spring-boot工程取名為server-zipkin,在其pom引入依賴:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
<dependencies>
 <dependency>
  <groupid>org.springframework.boot</groupid>
  <artifactid>spring-boot-starter</artifactid>
 </dependency>
 
 <dependency>
  <groupid>org.springframework.boot</groupid>
  <artifactid>spring-boot-starter-web</artifactid>
 </dependency>
 <dependency>
  <groupid>org.springframework.boot</groupid>
  <artifactid>spring-boot-starter-test</artifactid>
  <scope>test</scope>
 </dependency>
 
 <dependency>
  <groupid>io.zipkin.java</groupid>
  <artifactid>zipkin-server</artifactid>
 </dependency>
 
 <dependency>
  <groupid>io.zipkin.java</groupid>
  <artifactid>zipkin-autoconfigure-ui</artifactid>
 </dependency>
 
 </dependencies>
 
 <dependencymanagement>
 <dependencies>
  <dependency>
  <groupid>org.springframework.cloud</groupid>
  <artifactid>spring-cloud-dependencies</artifactid>
  <version>camden.sr6</version>
  <type>pom</type>
  <scope>import</scope>
  </dependency>
 </dependencies>
 </dependencymanagement>

在其程序入口類(lèi), 加上注解@enablezipkinserver,開(kāi)啟zipkinserver的功能:

?
1
2
3
4
5
6
7
8
@springbootapplication
@enablezipkinserver
public class serverzipkinapplication {
 
 public static void main(string[] args) {
 springapplication.run(serverzipkinapplication.class, args);
 }
}

在配置文件application.yml指定服務(wù)端口為:

?
1
server.port=9411

4.2 創(chuàng)建service-hi

在其pom引入起步依賴spring-cloud-starter-zipkin,代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
<dependencies>
 
 <dependency>
  <groupid>org.springframework.boot</groupid>
  <artifactid>spring-boot-starter-web</artifactid>
 </dependency>
 <!--compile('org.springframework.cloud:spring-cloud-starter-zipkin')-->
 
 <dependency>
  <groupid>org.springframework.cloud</groupid>
  <artifactid>spring-cloud-starter-zipkin</artifactid>
 </dependency>
 
 <dependency>
  <groupid>org.springframework.boot</groupid>
  <artifactid>spring-boot-starter-test</artifactid>
  <scope>test</scope>
 </dependency>
 </dependencies>
 
 <dependencymanagement>
 <dependencies>
  <dependency>
  <groupid>org.springframework.cloud</groupid>
  <artifactid>spring-cloud-dependencies</artifactid>
  <version>dalston.rc1</version>
  <type>pom</type>
  <scope>import</scope>
  </dependency>
 </dependencies>
 </dependencymanagement>

在其配置文件application.yml指定zipkin server的地址,頭通過(guò)配置“spring.zipkin.base-url”指定:

?
1
2
3
server.port=8988
spring.zipkin.base-url=http://localhost:9411
spring.application.name=service-hi

通過(guò)引入spring-cloud-starter-zipkin依賴和設(shè)置spring.zipkin.base-url就可以了。

對(duì)外暴露接口:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
@springbootapplication
@restcontroller
public class servicehiapplication {
 
 public static void main(string[] args) {
 springapplication.run(servicehiapplication.class, args);
 }
 
 private static final logger log = logger.getlogger(servicehiapplication.class.getname());
 
 
 @autowired
 private resttemplate resttemplate;
 
 @bean
 public resttemplate getresttemplate(){
 return new resttemplate();
 }
 
 @requestmapping("/hi")
 public string callhome(){
 log.log(level.info, "calling trace service-hi ");
 return resttemplate.getforobject("http://localhost:8989/miya", string.class);
 }
 @requestmapping("/info")
 public string info(){
 log.log(level.info, "calling trace service-hi ");
 
 return "i'm service-hi";
 
 }
 
 @bean
 public alwayssampler defaultsampler(){
 return new alwayssampler();
 }
}

4.3 創(chuàng)建service-miya

創(chuàng)建過(guò)程痛service-hi,引入相同的依賴,配置下spring.zipkin.base-url。

對(duì)外暴露接口:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
@springbootapplication
@restcontroller
public class servicemiyaapplication {
 
 public static void main(string[] args) {
 springapplication.run(servicemiyaapplication.class, args);
 }
 
 private static final logger log = logger.getlogger(servicemiyaapplication.class.getname());
 
 
 @requestmapping("/hi")
 public string home(){
 log.log(level.info, "hi is being called");
 return "hi i'm miya!";
 }
 
 @requestmapping("/miya")
 public string info(){
 log.log(level.info, "info is being called");
 return resttemplate.getforobject("http://localhost:8988/info",string.class);
 }
 
 @autowired
 private resttemplate resttemplate;
 
 @bean
 public resttemplate getresttemplate(){
 return new resttemplate();
 }
}

4.4 啟動(dòng)工程,演示追蹤

依次啟動(dòng)上面的三個(gè)工程,打開(kāi)瀏覽器訪問(wèn):http://localhost:9411/,會(huì)出現(xiàn)以下界面:

淺談Spring-cloud 之 sleuth 服務(wù)鏈路跟蹤

訪問(wèn):http://localhost:8989/miya,瀏覽器出現(xiàn):i'm service-hi

再打開(kāi)http://localhost:9411/的界面,點(diǎn)擊dependencies,可以發(fā)現(xiàn)服務(wù)的依賴關(guān)系:

淺談Spring-cloud 之 sleuth 服務(wù)鏈路跟蹤

點(diǎn)擊find traces,可以看到具體服務(wù)相互調(diào)用的數(shù)據(jù):

淺談Spring-cloud 之 sleuth 服務(wù)鏈路跟蹤

本文源碼下載: https://github.com/forezp/springcloudlearning/tree/master/chapter9

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:http://blog.csdn.net/forezp/article/details/70162074

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本在线一区二区 | 毛片a区 | 午夜影视一区二区 | 亚洲精品久久久久久久久久 | 把娇妻调教成暴露狂 | 免费看一级片 | 成人毛片网站 | 日韩精品一区二区三区中文 | 国产成人精品区一区二区不卡 | 欧美精品久久天天躁 | 中文字幕亚洲视频 | 成人情欲视频在线看免费 | 日本在线视频二区 | 久久久久久久久久久久99 | 国产高清自拍一区 | 亚洲成人黄色片 | 精品一区二区三区在线视频 | 国产一级片91 | 青青操国产| 92自拍视频 | 韩毛片| 91精品动漫在线观看 | 特级黄色小说 | 精品一区二区三区免费 | 狠狠操操 | 精品三区视频 | 爱福利视频网 | 久久久久九九九女人毛片 | 久久国产一二三 | 久久久久久久久久亚洲精品 | 高颜值美女啪啪 | 国产一区二区久久精品 | 黄色成人小视频 | 羞羞视频免费视频欧美 | 免费a级片在线观看 | 日韩免费黄色 | 日本中文字幕久久 | 国产91精品一区二区麻豆亚洲 | 欧美日韩1区2区3区 黄片毛片一级 | 草莓福利视频在线观看 | 高颜值美女啪啪 |