分布式链路追踪技术相关介绍

120 阅读2分钟

分布式链路追踪技术适用场景

为了支撑日益增长的庞大业务量,我们会使用微服务架构设计我们的系统,使得 我们的系统不仅能够通过集群部署抵挡流量的冲击,⼜能根据业务进⾏灵活的扩 展。 那么,在微服务架构下,⼀次请求少则经过三四次服务调⽤完成,多则跨越⼏⼗ 个甚⾄是上百个服务节点。那么问题接踵⽽来: 1)如何动态展示服务的调⽤链路?(⽐如A服务调⽤了哪些其他的服务---依赖 关系) 2)如何分析服务调⽤链路中的瓶颈节点并对其进⾏调优?(⽐如A—>B—>C,C 服务处理时间特别⻓) 3)如何快速进⾏服务链路的故障发现? 这就是分布式链路追踪技术存在的⽬的和意义 分布式链路追踪技术 如果我们在⼀个请求的调⽤处理过程中,在各个链路节点都能够记录下⽇志,并 最终将⽇志进⾏集中可视化展示,那么我们想监控调⽤链路中的⼀些指标就有希 望了比如,请求到达哪个服务实例?请求被处理的状态怎样?处理耗时怎 样?这些都能够分析出来了... 分布式环境下基于这种想法实现的监控技术就是就是分布式链路追踪(全链路追 踪)。

  • 市场上的分布式链路追踪方案 分布式链路追踪技术已然成熟,产品也不少,国内外都有,比如
  1. Spring Cloud Sleuth + Twitter Zipkin
  2. 阿里巴巴的“鹰眼”
  3. 大众点评的“CAT”
  4. 美团的“Mtrace”
  5. 京东的“Hydra”
  6. 新浪的“Watchman” 另外还有最近也被提到很多的 Apache Skywalking。