-
整合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中添加相关依赖:
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
总结
在这里,由于面试中MySQL问的比较多,因此也就在此以MySQL为例为大家总结分享。但是你要学习的往往不止这一点,还有一些主流框架的使用,Spring源码的学习,Mybatis源码的学习等等都是需要掌握的,我也把这些知识点都整理起来了
码的学习,Mybatis源码的学习等等都是需要掌握的,我也把这些知识点都整理起来了
[外链图片转存中…(img-RLEseevF-1721181849843)]
[外链图片转存中…(img-jmErnArC-1721181849844)]