Spring Cloud Sleuth:分布式请求链路跟踪
- Spring Cloud Sleuth 简介
- 给服务添加请求链路跟踪
- 整合Zipkin获取及分析日志
- 使用Elasticsearch存储跟踪信息
- 安装Elasticsearch
- 修改启动参数将信息存储到Elasticsearch
- 更多启动参数参考
- 福利
Spring Cloud Sleuth 简介 随着我们的系统越来越庞大,各个服务间的调用关系也变得越来越复杂。当客户端发起一个请求时,这个请求经过多个服务后,最终返回了结果,经过的每一个服务都有可能发生延迟或错误,从而导致请求失败。这时候我们就需要请求链路跟踪工具来帮助我们,理清请求调用的服务链路,解决问题。
给服务添加请求链路跟踪 我们将通过user-service和ribbon-service之间的服务调用来演示该功能,这里我们调用ribbon-service的接口时,ribbon-service会通过RestTemplate来调用user-service提供的接口。
- 首先给user-service和ribbon-service添加请求链路跟踪功能的支持;
- 在user-service和ribbon-service中添加相关依赖:
org.springframework.cloud
spring-cloud-starter-zipkin
- 修改application.yml文件,配置收集日志的zipkin-server访问地址:
spring:
zipkin:
base-url: http://localhost:9411
sleuth:
sampler:
probability: 0.1 #设置Sleuth的抽样收集概率
整合Zipkin获取及分析日志 Zipkin是Twitter的一个开源项目,可以用来获取和分析Spring Cloud Sleuth 中产生的请求链路跟踪日志,它提供了Web界面来帮助我们直观地查看请求链路跟踪信息。
- 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里面去了,重新启动也不会丢失;
# 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的话,可以看到里面已经存储了跟踪信息:
文章图片
福利
文章图片
微信搜一搜「 码上代码」回复【面试资料】,【技术书籍】有我准备的一线大厂面试资料和简历模板和java必看技术书籍
大家好,感谢各位人才
能看到这里的都是您已是佼佼者
我会持续为大家做技术分享
预知下篇如何
请点赞、收藏和评论,我们下期见!
推荐阅读
- 数据库|SQL SERVER数据库使用过程中系统提示死锁处理办法
- SpringCloud|Spring Cloud Stream函数式编程整合消息中间件
- 消息中间件|windows下安装RabbitMQ
- 60-spring 消费kafka, 推送消费到kafka
- SpringBoot学习笔记|SpringBoot配置文件优先级
- js|jquery 分页兼容i7,i8浏览器
- java|cocos2dx环境搭建
- 运维管理|Docker服务编排
- spring|SpringBoot自动配置原理入门