客户端Zipkin+Sleuth整合
通过查看日志分析微服务的调用链路并不是一个很直观的方案,结合zipkin可以很直观地显示微服务之间的调用关系。
(1)客户端添加依赖:
客户端指的是需要被追踪的微服务
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zipkin</artifactId> </dependency>
(2)修改客户端配置文件spring下:
zipkin: base-url: http://127.0.0.1:9411/ #server的请求地址 sender: type: web #数据的传输方式 , 已http的形式向server端发送数据 sleuth: sampler: probability: 1 #采样比
指定了zipkin server的地址,指定需采样的百分比:默认为0.1,即10%,这里配置1,是记录全部的sleuth信息,是为了收集到更多的数据(仅供测试用)。在分布式系统中,过于频繁的采样会影响系统性能,所以这里配置需要采用一个合适的值。
(3) 测试
以此启动每个微服务,启动Zipkin Service。通过浏览器发送一次微服务请求。打开 Zipkin Service控制台,我们可以根据条件追踪每次请求调用过程:
详情:
zipkin中存在的问题以及解决方案: