1.简介
(1)什么是服务追踪 Sleuth
在微服务架构中,要完成一个功能,通过Rest请求服务API调用服务来完成,整个调用过程可能会聚合多个后台服务器协同完成。在整个链路上,任何一处调用超时
或出错都有可能造成前端请求失败。这时跟踪记录这些请求的调用的情况就要复杂的多,这就需要一个专门的工具来处理,spring cloud sleuth组件就是用于跟踪记录的工具
Sleuth就相当于为微服务架构引入了一套记录体系,包含两部分,一个是 trace ID;另一个是 span ID,随时记录一个请求的每一步操作。
(2)什么是日志聚合 Zipkin
zipkin 是 Dpper的开源实现,支持多种语言。Sleuth已经将每个请求从开始调用到完成的每一步都进行了记录,但是这些log信息会很分散,使用起来不太方便,就
需要有一个工具可以将这些信息进行收集和汇总,并且显示可视化的结果,便于分析和定位。这就需要创建一个 Zipkin Server用于收集和展示这些调用链路的信息,他
的使用也很方便。
2.如何使用
本例需要创建三个工程:
product-sevice 普通客户端工程,提供一个rest接口(项目创建参考第三节)
order-service 普通客户端工程,用于调用product-service服务(项目创建参考第三节)
zipkin-service 日志服务工程,用于追踪记录请求链路。
第一步:创建 zipkin-service,作为Zipkin Server。
工程目录如图:
(1)首先在 pom.xml中增加依赖
<dependency>
<groupId>io.zipkin.java</groupId>
<artifactId>zipkin-autoconfigure-ui&l