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

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

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

Spring Cloud Sleuth 简介

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

给服务添加请求链路跟踪

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

  • 首先给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:9411sleuth: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的话,可以看到里面已经存储了跟踪信息:

更多启动参数参考

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

福利

微信搜一搜「 码上代码」回复【面试资料】,【技术书籍】有我准备的一线大厂面试资料和简历模板和java必看技术书籍

大家好,感谢各位人才
能看到这里的都是您已是佼佼者
我会持续为大家做技术分享
预知下篇如何
点赞、收藏和评论,我们下期见!

五分钟学会 Spring Cloud Sleuth:分布式请求链路跟踪(小白必看,一看就会教程)相关推荐

  1. SpringCloud学习笔记(十二)Sleuth 分布式请求链路跟踪

    目录 一.Sleuth介绍 1.为什么会出现这个技术?需要解决哪些问题? 2.是什么 二.搭建链路监控步骤 1.zipkin搭建安装 1)下载 2)运行jar 3)运行控制台 4)术语 2.服务提供者 ...

  2. java https请求_Spring Cloud Sleuth:分布式请求链路跟踪

    Spring Cloud Sleuth 是分布式系统中跟踪服务间调用的工具,它可以直观地展示出一次请求的调用过程,本文将对其用法进行详细介绍. Spring Cloud Sleuth 简介 随着我们的 ...

  3. SpringCloud Sleuth分布式请求链路追踪

    概念 1. 为什么需要链路追踪? 在微服务框架中,一个由客户端发起的请求在后端系统中 会经过多个不同的的服务节点调用来协同产生最后的请求结果, 每一个前段请求都会形成一复杂的分布式服务调用链路, 链路 ...

  4. SpringCloud 2020版本教程4:使用spring cloud sleuth+zipkin实现链路追踪

    点击关注公众号,Java干货及时送达 Spring Cloud Sleuth 主要功能就是在分布式系统中提供追踪解决方案,并且兼容支持了 zipkin,你只需要在pom文件中引入相应的依赖即可. 微服 ...

  5. 五分钟学会 Spring Boot Admin:微服务应用监控(小白必看,一看就会教程)

    Spring Boot Admin:微服务应用监控 Spring Boot Admin 简介 监控信息演示 结合注册中心使用 功能演示 添加登录认证 文末福利 Spring Boot Admin 可以 ...

  6. 【Spring Cloud Sleuth 分布式链路跟踪】 —— 每天一点小知识

  7. 基于docker部署的微服务架构(九): 分布式服务追踪 Spring Cloud Sleuth

    为什么80%的码农都做不了架构师?>>>    前言 微服务架构中完成一项功能经常会在多个服务之间远程调用(RPC),形成调用链.每个服务节点可能在不同的机器上甚至是不同的集群上,需 ...

  8. Spring微服务实战第9章 使用Spring Cloud Sleuth和Zipkin进行分布式跟踪

    文章目录 第9章 使用Spring Cloud Sleuth和Zipkin进行分布式跟踪 9.1 Spring Cloud Sleuth与关联ID 9.1.1 将Spring Cloud Sleuth ...

  9. 分布式链路追踪之Spring Cloud Sleuth夺命连环9问?

    点击上方☝码猿技术专栏 轻松关注,设为星标! 及时获取有趣有料的技术 大家好,我是不才陈某~ 这是<Spring Cloud 进阶>第九篇文章,往期文章如下: 五十五张图告诉你微服务的灵魂 ...

最新文章

  1. 邮件回复功能失效 谁遇到过?
  2. 导出Excel出现“异常来自 HRESULT:0x800A03EC”错误的解决方法(已验证)
  3. startservice方式启动服务
  4. Java每天10道面试题,跟我走,offer有!(七)
  5. Mysql事务隔离级别及MVCC(多版本并发控制)
  6. UE4入门学习3:GamePlay框架
  7. serverless搭建html,基于ServerLess的极简网页计数器:源码分析与实践
  8. pdf在线翻译_如何将英文的PDF文档翻译成中文简体?
  9. (三)线程同步工具集_1---控制线程并发访问一个资源
  10. Hbase与pegasus对比
  11. 【21天python打卡】第15天 python经典案例(1)
  12. Win10 激活工具被删除或“无法成功完成操作,因为文件包含病毒或潜在的垃圾软件”
  13. Ps 2022 版新增功能及改进
  14. slam是什么意思?一文带你读懂SLAM
  15. Python数据分析_第06课:数据清洗与初步分析_笔记
  16. jdk动态代理proxy
  17. 中关村软件园与百度飞桨启动AI人才培养计划:AI发展,人才先行
  18. 非线性规划 - 数学建模
  19. Raphael 使用手记
  20. 模拟生态圈_揭秘美国造价16亿的火星模拟生物圈,曾进行过2年的密封生存实验...

热门文章

  1. 怎么把动图放到word里_如何word里插入会动的gif图
  2. 布隆过滤器(Bloom Filter)算法
  3. 【转】我的WIN7分辨率是1920*1080,调低后字体模糊
  4. GPU+windows 10+vs2013+cuda7.5环境下配置caffe框架
  5. 动态规划——0/1背包问题(全网最细+图文解析)
  6. 前端面试题---小米(总结知识点)
  7. Hive详细介绍及简单应用
  8. 7-12 计算存款利息 (5 分)
  9. Android KEYCODE键值对应大全
  10. 我的世界基岩版和java版的种子_我的世界:手机版新手地图种子,PC基岩版通用,快点记下来吧!...