SpringBoot实战电商项目mall(20k+star)地址:github.com/macrozheng/…java
Spring Cloud Sleuth 是分布式系统中跟踪服务间调用的工具,它能够直观地展现出一次请求的调用过程,本文将对其用法进行详细介绍。git
随着咱们的系统愈来愈庞大,各个服务间的调用关系也变得愈来愈复杂。当客户端发起一个请求时,这个请求通过多个服务后,最终返回告终果,通过的每个服务都有可能发生延迟或错误,从而致使请求失败。这时候咱们就须要请求链路跟踪工具来帮助咱们,理清请求调用的服务链路,解决问题。github
咱们将经过user-service和ribbon-service之间的服务调用来演示该功能,这里咱们调用ribbon-service的接口时,ribbon-service会经过RestTemplate来调用user-service提供的接口。spring
首先给user-service和ribbon-service添加请求链路跟踪功能的支持;bash
在user-service和ribbon-service中添加相关依赖:app
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zipkin</artifactId>
</dependency>
复制代码
spring:
zipkin:
base-url: http://localhost:9411
sleuth:
sampler:
probability: 0.1 #设置Sleuth的抽样收集几率
复制代码
Zipkin是Twitter的一个开源项目,能够用来获取和分析Spring Cloud Sleuth 中产生的请求链路跟踪日志,它提供了Web界面来帮助咱们直观地查看请求链路跟踪信息。elasticsearch
SpringBoot 2.0以上版本已经不须要自行搭建zipkin-server,咱们能够从该地址下载zipkin-server:repo1.maven.org/maven2/io/z…maven
下载完成后使用如下命令运行zipkin-server:分布式
java -jar zipkin-server-2.12.9-exec.jar
复制代码
若是咱们把zipkin-server重启一下就会发现刚刚的存储的跟踪信息所有丢失了,可见其是存储在内存中的,有时候咱们须要将全部信息存储下来,这里以存储到Elasticsearch为例,来演示下该功能。工具
# STORAGE_TYPE:表示存储类型 ES_HOSTS:表示ES的访问地址
java -jar zipkin-server-2.12.9-exec.jar --STORAGE_TYPE=elasticsearch --ES_HOSTS=localhost:9200
复制代码
以后须要从新启动user-service和ribbon-service才能生效,重启后屡次调用ribbon-service的接口http://localhost:8301/user/1;
若是安装了Elasticsearch的可视化工具Kibana的话,能够看到里面已经存储了跟踪信息:
springcloud-learning
├── eureka-server -- eureka注册中心
├── user-service -- 提供User对象CRUD接口的服务
└── ribbon-service -- ribbon服务调用测试服务
复制代码
mall项目全套学习教程连载中,关注公众号第一时间获取。