小白一看就会的 Spring Cloud Sleuth:分布式请求链路跟踪 建议收藏!

 

养成阅读好习惯,从关注开始!java

更多Java相关资料能够关注公众号【Java大蜗牛】发送:6git

Spring Cloud Sleuth:分布式请求链路跟踪github

  • Spring Cloud Sleuth 简介
  • 给服务添加请求链路跟踪
  • 整合Zipkin获取及分析日志
  • 使用Elasticsearch存储跟踪信息
  • 安装Elasticsearch
  • 修改启动参数将信息存储到Elasticsearch
  • 更多启动参数参考

Spring Cloud Sleuth 是分布式系统中跟踪服务间调用的工具,它能够直观地展现出一次请求的调用过程,本文将对其用法进行详细介绍。spring

Spring Cloud Sleuth 简介

随着咱们的系统愈来愈庞大,各个服务间的调用关系也变得愈来愈复杂。当客户端发起一个请求时,这个请求通过多个服务后,最终返回告终果,通过的每个服务都有可能发生延迟或错误,从而致使请求失败。这时候咱们就须要请求链路跟踪工具来帮助咱们,理清请求调用的服务链路,解决问题。app

给服务添加请求链路跟踪

咱们将经过user-service和ribbon-service之间的服务调用来演示该功能,这里咱们调用ribbon-service的接口时,ribbon-service会经过RestTemplate来调用user-service提供的接口。elasticsearch

  • 首先给user-service和ribbon-service添加请求链路跟踪功能的支持;
  • 在user-service和ribbon-service中添加相关依赖:
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-zipkin</artifactId>
</dependency>
  • 修改application.yml文件,配置收集日志的zipkin-server访问地址:
spring:
  zipkin:
    base-url: http://localhost:9411
  sleuth:
    sampler:
      probability: 0.1 #设置Sleuth的抽样收集几率

整合Zipkin获取及分析日志

Zipkin是Twitter的一个开源项目,能够用来获取和分析Spring Cloud Sleuth 中产生的请求链路跟踪日志,它提供了Web界面来帮助咱们直观地查看请求链路跟踪信息。maven

  • SpringBoot
    2.0以上版本已经不须要自行搭建zipkin-server,咱们能够从该地址下载zipkin-server:
  • https://repo1.maven.org/maven2/io/zipkin/java/zipkin-server/2.12.9/zipkin-server-2.12.9-exec.jar
  • 下载完成后使用如下命令运行zipkin-server:
java -jar zipkin-server-2.12.9-exec.jar
  • Zipkin页面访问地址:http://localhost:9411

 

  • 启动eureka-sever,ribbon-service,user-service:

 

  • 屡次调用(Sleuth为抽样收集)ribbon-service的接口http://localhost:8301/user/1
    ,调用完后查看Zipkin首页发现已经有请求链路跟踪信息了;

 

  • 点击查看详情能够直观地看到请求调用链路和经过每一个服务的耗时:

 

  • 使用Elasticsearch存储跟踪信息
  • 下载Elasticsearch6.2.2的zip包,并解压到指定目录,下载地址:https://www.elastic.co/cn/downloads/past-releases/elasticsearch-6-2-2

 

  • 运行bin目录下的elasticsearch.bat启动Elasticsearch

 

  • 修改启动参数将信息存储到Elasticsearch
  • 使用如下命令运行,就能够把跟踪信息存储到Elasticsearch里面去了,从新启动也不会丢失;

更多启动参数参考

https://github.com/openzipkin/zipkin/tree/master/zipkin-server#elasticsearch-storage分布式

好了,今天的文章就分享到这里,更多Java相关资料能够关注公众号【Java大蜗牛】发送:6工具

相关文章
相关标签/搜索