您好,登錄后才能下訂單哦!
本文源碼:GitHub·點這里 || GitEE·點這里
Sleuth是SpringCloud微服務系統中的一個組件,實現了鏈路追蹤解決方案。可以定位一個請求到底請求了哪些具體的服務。在復雜的微服務系統中,如果請求發生了異常,可以快速捕獲問題所在的服務。
* 注冊中心
node07-eureka-7001
* 鏈路數據收集服務
node07-zipkin-7003
* 服務提供
node07-provider-6001
node07-provider-6002
* 網關路由
node07-zuul-7002
<dependency>
<groupId>io.zipkin.java</groupId>
<artifactId>zipkin-server</artifactId>
</dependency>
<dependency>
<groupId>io.zipkin.java</groupId>
<artifactId>zipkin-autoconfigure-ui</artifactId>
</dependency>
server:
port: 7003
spring:
application:
name: node07-zipkin-7003
eureka:
instance:
hostname: zipkin-7003
prefer-ip-address: true
client:
service-url:
defaultZone: http://registry01.com:7001/eureka/
這里網關,zuul-7002,服務提供,provider-6001,provider-6002的配置相同。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zipkin</artifactId>
</dependency>
spring:
zipkin:
base-url: http://localhost:7003
sleuth:
sampler:
# 數據 100% 上傳
percentage: 1.0
一次啟動上述服務之后,查看注冊中心:
訪問接口
http://localhost:7002/v1/api-6001/get6001Info
這個請求從網關服務進入,到達6001端口服務之后,請求6002端,最終返回結果。
@Autowired
private RestTemplate restTemplate ;
@RequestMapping("/get6001Info")
public String get6001Info (){
String server_name = "http://node07-provider-6002" ;
return restTemplate.getForObject(server_name+"/get6002Info",String.class) ;
}
@RequestMapping(value = "/get6002Info",method = RequestMethod.GET)
public String get6002Info () {
LOG.info("provider-6002");
return "6002Info" ;
}
1)、UI界面
訪問接口
http://localhost:7003/zipkin/
2)、依賴分析
如圖點擊,【依賴分析】,和上面描述的請求過程完全一致。
GitHub·地址
https://github.com/cicadasmile/spring-cloud-base
GitEE·地址
https://gitee.com/cicadasmile/spring-cloud-base
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。