wordpress本站运行,wordpress 微信二维码,花灯制作,wordpress无限地址这里写目录标题 1 分布式链路追踪概述1.1 为什么会出现这个技术#xff1f;需要解决哪些问题#xff1f;1.2 在分布式与微服务场景下需要解决的问题 2 新一代Spring Cloud Sleuth#xff1a;Micrometer2.1 官网重要提示2.1.1 新一代Sleuth2.1.2 官网2.1.3 说明2.1.3.1 老项目… 这里写目录标题 1 分布式链路追踪概述1.1 为什么会出现这个技术需要解决哪些问题1.2 在分布式与微服务场景下需要解决的问题 2 新一代Spring Cloud SleuthMicrometer2.1 官网重要提示2.1.1 新一代Sleuth2.1.2 官网2.1.3 说明2.1.3.1 老项目还能用Sleuth开发吗2.1.3.2 版本注意 2.2 zipkin那2.3 小总结2.4 行业内比较成熟的其它分布式链路追踪技术解决方案 3 分布式链路追踪原理4 Zipkin4.1 是什么4.2 Zipkin为什么出现?4.3 下载安装运行一套带走4.3.1 下载主页4.3.2 下载地址4.3.3 运行jar4.3.4 运行控制台 5 MicrometerZipKin搭建链路监控案例步骤5.1 步骤5.1.1 依赖包介绍5.1.2 总体父工程POM5.1.3 服务提供者80015.1.3.1 POM5.1.3.2 YML5.1.3.3 新增PayMicrometerController 5.1.4 Api接口PayFeignApi5.1.5 服务调用者805.1.5.1 POM5.1.5.2 YML5.1.5.3 新增OrderMicrometerController 5.2 打开浏览器访问http://localhost:9411 通过百度网盘分享的文件springcloud 链接https://pan.baidu.com/s/1lTChHsKgJpvvFRnq7WQImQ 提取码msr3
1 分布式链路追踪概述
1.1 为什么会出现这个技术需要解决哪些问题
在微服务框架中一个由客户端发起的请求在后端系统中会经过多个不同的的服务节点调用来协同产生最后的请求结果每一个前段请求都会形成一条复杂的分布式服务调用链路链路中的任何一环出现高延时或错误都会引起整个请求最后的失败
1.2 在分布式与微服务场景下需要解决的问题
在分布式与微服务场景下我们需要解决如下问题
在大规模分布式与微服务集群下如何实时观测系统的整体调用链路情况。 在大规模分布式与微服务集群下如何快速发现并定位到问题。 在大规模分布式与微服务集群下如何尽可能精确的判断故障对系统的影响范围与影响程度。 在大规模分布式与微服务集群下如何尽可能精确的梳理出服务之间的依赖关系并判断出服务之间的依赖关系是否合理。 在大规模分布式与微服务集群下如何尽可能精确的分析整个系统调用链路的性能与瓶颈点。 在大规模分布式与微服务集群下如何尽可能精确的分析系统的存储瓶颈与容量规划。
上述问题就是我们的落地议题答案 分布式链路追踪技术要解决的问题分布式链路追踪Distributed Tracing就是将一次分布式请求还原成调用链路进行日志记录性能监控并将一次分布式请求的调用情况集中展示。比如各个服务节点上的耗时、请求具体到达哪台机器上、每个服务节点的请求状态等等。
2 新一代Spring Cloud SleuthMicrometer
2.1 官网重要提示
2.1.1 新一代Sleuth
sleuth被micrometer替代 https://micrometer.io/docs/tracing
2.1.2 官网
官网:https://spring.io/projects/spring-cloud-sleuth#overview github:https://github.com/spring-cloud/spring-cloud-sleuth
2.1.3 说明
2.1.3.1 老项目还能用Sleuth开发吗 2.1.3.2 版本注意 2.2 zipkin那
Spring Cloud Sleuth(micrometer)提供了一套完整的分布式链路追踪Distributed Tracing) 解决方案且兼容支持了zipkin展现
2.3 小总结
将一次分布式请求还原成调用链路进行日志记录和性能监控并将一次分布式请求的调用情况集中web展示
2.4 行业内比较成熟的其它分布式链路追踪技术解决方案 3 分布式链路追踪原理
假定3个微服务调用的链路:Service1调用Service2Service2调用Service3和Service4
那么一条链路追踪会在每个服务调用的时候加上Trace ID 和 Span ID 链路通过TraceId唯一标识 Span标识发起的请求信息各span通过parent id 关联起来 (Span:表示调用链路来源通俗的理解span就是一次请求信息)
一条链路通过Trace Id唯一标识Span标识发起的请求信息各span通过parent id 关联起来
步骤逻辑1第一个节点Span ID AParent ID nullService 1 接收到请求。2第二个节点Span ID BParent ID AService 1 发送请求到 Service 2 返回响应给Service 1 的过程。3第三个节点Span ID CParent ID BService 2 的 中间解决过程。4第四个节点Span ID DParent ID CService 2 发送请求到 Service 3 返回响应给Service 2 的过程。5第五个节点Span ID EParent ID DService 3 的中间解决过程。6第六个节点Span ID FParent ID CService 3 发送请求到 Service 4 返回响应给 Service 3 的过程。7第七个节点Span ID GParent ID FService 4 的中间解决过程。8通过 Parent ID 就可找到父节点整个链路即可以进行跟踪追溯了。
4 Zipkin
官网:https://zipkin.io/
4.1 是什么
ZipKin概述
Zipkin是一种分布式链路跟踪系统图形化的工具Zipkin 是 Twitter 开源的分布式跟踪系统能够收集微服务运行过程中的实时调用链路信息并能够将这些调用链路信息展示到Web图形化界面上供开发人员分析开发人员能够从ZipKin中分析出调用链路中的性能瓶颈识别出存在问题的应用程序进而定位问题和解决问题。
4.2 Zipkin为什么出现?
单有Sleuth(Micrometer)行不行 说明 当没有配置 Sleuth 链路追踪的时候INFO 信息里面是 [passjava-question,]后面跟着三个空字符串。
当配置了 Sleuth 链路追踪的时候追踪到的信息是 [passjava-question,504a5360ca906016,e55ff064b3941956,false] 第一个是 Trace ID第二个是 Span ID。只有日志没有图观看不方便不美观so引入图形化Zipkin链路监控让你好看O(∩_∩)O
4.3 下载安装运行一套带走
4.3.1 下载主页
https://zipkin.io/pages/quickstart
4.3.2 下载地址
https://zipkin.io/pages/quickstart 2023.12版本名称 zipkin-server-3.0.0-rc0-exec.jar
4.3.3 运行jar
java -jar zipkin-server-3.0.0-rc0-exec.jar
4.3.4 运行控制台
http://localhost:9411/zipkin/
5 MicrometerZipKin搭建链路监控案例步骤
MicrometerZipKin两者各自的分工 Micrometer数据采样 ZipKin图形展示
5.1 步骤
5.1.1 依赖包介绍
由于Micrometer Tracing是一个门面工具自身并没有实现完整的链路追踪系统具体的链路追踪另外需要引入的是第三方链路追踪系统的依赖
1micrometer-tracing-bom导入链路追踪版本中心体系化说明2micrometer-tracing指标追踪3micrometer-tracing-bridge-brave一个Micrometer模块用于与分布式跟踪工具 Brave 集成以收集应用程序的分布式跟踪数据。Brave是一个开源的分布式跟踪工具它可以帮助用户在分布式系统中跟踪请求的流转它使用一种称为跟踪上下文的机制将请求的跟踪信息存储在请求的头部然后将请求传递给下一个服务。在整个请求链中Brave会将每个服务处理请求的时间和其他信息存储到跟踪数据中以便用户可以了解整个请求的路径和性能。4micrometer-observation一个基于度量库 Micrometer的观测模块用于收集应用程序的度量数据。5feign-micrometer一个Feign HTTP客户端的Micrometer模块用于收集客户端请求的度量数据。6zipkin-reporter-brave一个用于将 Brave 跟踪数据报告到Zipkin 跟踪系统的库。
补充包spring-boot-starter-actuator SpringBoot框架的一个模块用于监视和管理应用程序
5.1.2 总体父工程POM propertiesmicrometer-tracing.version1.2.0/micrometer-tracing.versionmicrometer-observation.version1.12.0/micrometer-observation.versionfeign-micrometer.version12.5/feign-micrometer.versionzipkin-reporter-brave.version2.17.0/zipkin-reporter-brave.version/propertiesdependencyManagement
dependencies
!--micrometer-tracing-bom导入链路追踪版本中心 1--
dependencygroupIdio.micrometer/groupIdartifactIdmicrometer-tracing-bom/artifactIdversion${micrometer-tracing.version}/versiontypepom/typescopeimport/scope
/dependency
!--micrometer-tracing指标追踪 2--
dependencygroupIdio.micrometer/groupIdartifactIdmicrometer-tracing/artifactIdversion${micrometer-tracing.version}/version
/dependency
!--micrometer-tracing-bridge-brave适配zipkin的桥接包 3--
dependencygroupIdio.micrometer/groupIdartifactIdmicrometer-tracing-bridge-brave/artifactIdversion${micrometer-tracing.version}/version
/dependency
!--micrometer-observation 4--
dependencygroupIdio.micrometer/groupIdartifactIdmicrometer-observation/artifactIdversion${micrometer-observation.version}/version
/dependency
!--feign-micrometer 5--
dependencygroupIdio.github.openfeign/groupIdartifactIdfeign-micrometer/artifactIdversion${feign-micrometer.version}/version
/dependency
!--zipkin-reporter-brave 6--
dependencygroupIdio.zipkin.reporter2/groupIdartifactIdzipkin-reporter-brave/artifactIdversion${zipkin-reporter-brave.version}/version
/dependency/dependencies
/dependencyManagement5.1.3 服务提供者8001
cloud-provider-payment8001
5.1.3.1 POM
5个jar包
!--micrometer-tracing指标追踪 1--dependencygroupIdio.micrometer/groupIdartifactIdmicrometer-tracing/artifactId/dependency!--micrometer-tracing-bridge-brave适配zipkin的桥接包 2--dependencygroupIdio.micrometer/groupIdartifactIdmicrometer-tracing-bridge-brave/artifactId/dependency!--micrometer-observation 3--dependencygroupIdio.micrometer/groupIdartifactIdmicrometer-observation/artifactId/dependency!--feign-micrometer 4--dependencygroupIdio.github.openfeign/groupIdartifactIdfeign-micrometer/artifactId/dependency!--zipkin-reporter-brave 5--dependencygroupIdio.zipkin.reporter2/groupIdartifactIdzipkin-reporter-brave/artifactId/dependency5.1.3.2 YML
# zipkin
management:zipkin:tracing:endpoint: http://localhost:9411/api/v2/spanstracing:sampling:probability: 1.0 #采样率默认为0.1(0.1就是10次只能有一次被记录下来)值越大收集越及时。5.1.3.3 新增PayMicrometerController
RestController
public class PayMicrometerController
{/*** Micrometer(Sleuth)进行链路监控的例子* param id* return*/GetMapping(value /pay/micrometer/{id})public String myMicrometer(PathVariable(id) Integer id){return Hello, 欢迎到来myMicrometer inputId: id \t 服务返回: IdUtil.simpleUUID();}
}5.1.4 Api接口PayFeignApi /*** Micrometer(Sleuth)进行链路监控的例子* param id* return*/GetMapping(value /pay/micrometer/{id})public String myMicrometer(PathVariable(id) Integer id);5.1.5 服务调用者80
cloud-consumer-feign-order80
5.1.5.1 POM
!--micrometer-tracing指标追踪 1--dependencygroupIdio.micrometer/groupIdartifactIdmicrometer-tracing/artifactId/dependency!--micrometer-tracing-bridge-brave适配zipkin的桥接包 2--dependencygroupIdio.micrometer/groupIdartifactIdmicrometer-tracing-bridge-brave/artifactId/dependency!--micrometer-observation 3--dependencygroupIdio.micrometer/groupIdartifactIdmicrometer-observation/artifactId/dependency!--feign-micrometer 4--dependencygroupIdio.github.openfeign/groupIdartifactIdfeign-micrometer/artifactId/dependency!--zipkin-reporter-brave 5--dependencygroupIdio.zipkin.reporter2/groupIdartifactIdzipkin-reporter-brave/artifactId/dependency5.1.5.2 YML
# zipkin图形展现地址和采样率设置
management:zipkin:tracing:endpoint: http://localhost:9411/api/v2/spanstracing:sampling:probability: 1.0 #采样率默认为0.1(0.1就是10次只能有一次被记录下来)值越大收集越及时。5.1.5.3 新增OrderMicrometerController
RestController
Slf4j
public class OrderMicrometerController
{Resourceprivate PayFeignApi payFeignApi;GetMapping(value /feign/micrometer/{id})public String myMicrometer(PathVariable(id) Integer id){return payFeignApi.myMicrometer(id);}
}5.2 打开浏览器访问http://localhost:9411 查看依赖关系