概述
sleuth可以将调用日志(Trace +Span)发给Zipkin进行存储、分析。
Zipkin可以将收集到的分布式日志,整合成服务调用链,方便分析及查找问题。
实战
Zipkin
-
下载Zipkin
从官网(https://zipkin.io)下载 Zipkin (有docker 及 jar 两种方式),本示例采用下载 jar 包的方式
-
启动Zipkin
java -jar zipkin-server-2.12.9-exec.jar
data:image/s3,"s3://crabby-images/99e13/99e1359770435dfe744474b5f385cc5bad8bd121" alt=""
-
WEB管理页面
[WEB管理页面URL] http://localhost:9411/
data:image/s3,"s3://crabby-images/23ec5/23ec52dc6c519fe64d6a5793630f66ca683721ac" alt=""
目前还没有日志数据,需要配置sleuth收集追踪日志,并将日志发送给Zipkin。
Zipkin默认使用内存存储数据,重启服务后,数据会丢失。可以配置为持久化的存储方案。
sleuth
-
添加依赖(pom.xml)
<!-- sleuth -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-sleuth</artifactId>
</dependency>
<!-- zipkin client -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zipkin</artifactId>
</dependency>
-
配置(application.properties)
# sleuth只能收集DEBUG级别日志(这里定义了收集日志的范围)
logging.level.org.springframework.web.servlet.DispatcherServlet=DEBUG
# 收集日志的比例,取值范围为0-1(缺省为0.1,即只收集10%的日志): 为了方便验证效果设为1
#spring.sleuth.sampler.rate=1
# zipkin服务器URL (sleuth会将收集到的日志报告给zipkin)
spring.zipkin.baseUrl=http://localhost:9411
查看日志
-
重启服务,访问consumer应用
重新启动相关的服务,使用浏览器访问consumer应用,
data:image/s3,"s3://crabby-images/61526/6152672d158fcd2ca4a2f2b38b8031d872cd1cc5" alt=""
-
查看consumer应用的日志
data:image/s3,"s3://crabby-images/1cae5/1cae581a78741de0a290db4c882e4472fd048914" alt=""
-
通过Zipkin WEB管理页面查看日志分析结果
data:image/s3,"s3://crabby-images/93f51/93f511409aed5812d1c4cc2b367080a559f41ad2" alt=""
点击其中一个调用链,可查看详细情况,如下图
data:image/s3,"s3://crabby-images/7e00d/7e00d79f57f32bd46580078d5203a73624aaf694" alt=""
调用模拟异常
将provider项目手工停止,再次访问测试服务后,进入Zipkin的WEB管理页面,可查看到调用的过程及状态。
data:image/s3,"s3://crabby-images/6f380/6f380e69d4f34024da3bd138a186f051c77e75e1" alt=""
网友评论