spring cloud 微服务链路追踪系统 Sleuth和zipkin 概述

微服务链路追踪系统的作用

抛两个常见的问题

  • 微服务调用链路出现了问题怎么快速排查?

  • 微服务调用链路耗时长怎么定位是哪个服务?

分布式应用架构虽然满足了应用横向扩展的需求,但是运维和诊断的过程变得越来越复杂,例如会遇到接口诊断困难、应用性能诊断复杂、架构分析复杂等难题,传统的监控工具并无法满足,分布式链路系统由此诞生

核心:将一次请求分布式调用,使用GPS定位串起来,记录每个调用的耗时、性能等日志,并通过可视化工具展示出来

注意:AlibabaCloud全家桶还没对应的链路追踪系统,我们使用Sleuth和zipking(内部使用的鹰眼)

 

什么是Sleuth
一个组件,专门用于记录链路数据的开源组件
案例,此为idea项目的日志打印
    [order-service,96f95a0dd81fe3ab,852ef4cfcdecabf3,false]
    第一个值,spring.application.name的值
    第二个值,96f95a0dd81fe3ab ,sleuth生成的一个ID,叫Trace ID,用来标识一条请求链路,一条请求链路中包含一个Trace ID,多个Span ID
    第三个值,852ef4cfcdecabf3、spanid 基本的工作单元,获取元数据,如发送一个http
    第四个值:false,是否要将该信息输出到zipkin服务中来收集和展示。
    


什么是zipkin
大规模分布式系统的APM工具(Application Performance Management),基于Google Dapper的基础实现,和sleuth结合可以提供可视化web界面分析调用链路耗时情况

同类产品

  • 鹰眼(EagleEye)

  • CAT

  • twitter开源zipkin,结合sleuth
  • Pinpoint,运用JavaAgent字节码增强技术

StackDriver Trace (Google)

开始使用zipkin

启动服务
java -jar zipkin-server-2.12.9-exec.jar
访问入口:http://127.0.0.1:9411/zipkin/
zipkin组成:Collector、Storage、Restful API、Web UI组成
spring cloud 微服务链路追踪系统 Sleuth和zipkin 概述_第1张图片

使用Zipkin+Sleuth业务分析调用链路分析实战

sleuth收集跟踪信息通过http请求发送给zipkin server
zipkin server进行跟踪信息的存储以及提供Rest API即可
Zipkin UI调用其API接口进行数据展示默认存储是内存也可mysql 或者elasticsearch存储
spring cloud 微服务链路追踪系统 Sleuth和zipkin 概述_第2张图片
spring cloud 微服务链路追踪系统 Sleuth和zipkin 概述_第3张图片

你可能感兴趣的:(#,SpringCloud,spring,cloud,微服务,分布式)