SpringCloud 引入链路跟踪Sleuth及Zipkin

Zipkin是一种分布式跟踪系统,它有助于收集解决微服务架构中得延迟问题所需的时序数据,它管理这些数据的收集和查找。

下载 官方推荐直接下载打包好的应用,建议使用docker镜像或者jar

使用官方一键脚本

curl -sSL https://zipkin.io/quickstart.sh | bash -s
java -jar zipkin.jar

docker

docker run -d -p 9411:9411 openzipkin/zipkin

访问

任一方式启动后,访问 http://localhost:9411/zipkin/ ,如下图

SpringCloud 引入链路跟踪Sleuth及Zipkin

项目集成

2.pom.xml 配置

增加如下依赖

<dependency>
 <groupId>org.springframework.cloud</groupId>
 <artifactId>spring-cloud-starter-zipkin</artifactId>
 <version>2.0.3.RELEASE</version>
</dependency>

如果项目中包含 aspectjweaver 这个jar ,需要指定jar包版本为1.8.10,否则项目启动会出错

<dependency>
 <groupId>org.aspectj</groupId>
 <artifactId>aspectjweaver</artifactId>
 <version>1.8.10</version>
</dependency>

配置采样等参数

#zipkin配置 # 指定了 Zipkin 服务器的地址
spring.zipkin.base-url = http://localhost:9411/ 
#采样率 1.0表示全部采样
spring.sleuth.sampler.probability = 1.0

服务调用以后,就可以看到具体的调用请求时间,但是在这个过程中也碰到了一些问题

  • 如果屏蔽一些接口记录,例如 健康检查会产生大量的无用数据,影响查询
  • 如果使用mysql查询会有一定的影响,官方也不建议使用
  • 使用官方的jar后,无法进行改造,满足不了一些额外的需求
  • 存储数据安全规范等问题

如果使用ES进行存储(建议使用)

# STORAGE_TYPE 指定存储类型 ES_HOSTS es ip 通过逗号隔开,可以使用多个,ES_USERNAME ES用户名 ES_PASSWORD ES密码 ES_INDEX 自定义存储索引
STORAGE_TYPE=elasticsearch ES_HOSTS=172.16.28.56:9200,172.16.28.57:9200  ES_USERNAME=admin ES_PASSWORD=123456 ES_INDEX=zipkin-trace  java -jar /zipkin.jar

原文 

https://blog.searchinfogo.com/2020/03/19/spring-seluth-zipkin/

本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。

PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » SpringCloud 引入链路跟踪Sleuth及Zipkin

赞 (0)
分享到:更多 ()

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址