zipkin dubbo mysql_Dubbo + Zipkin + Brave 实现全链路追踪

07a667669f11751af027619f8295cfdf.png

作者:BakerZhu

链接:

https://my.oschina.net/LucasZhu/blog/2051269

最近写了一个链路追踪Demo分享下,实现了链路追踪过程中数据的记录,还有能扩展的地方,后期再继续补充。

原理参考上面文章 《Dubbo链路追踪——生成全局ID(traceId)》:

https://my.oschina.net/LucasZhu/blog/2046356

实现链路追踪的目的

服务调用的流程信息,定位服务调用链

记录调用入参及返回值信息,方便问题重现

记录调用时间线,代码重构及调优处理

调用信息统计

分布式跟踪系统还有其他比较成熟的实现,例如:Naver的Pinpoint、Apache的HTrace、阿里的鹰眼Tracing、京东的Hydra、新浪的Watchman,美团点评的CAT,skywalking等。 本次主要利用Dubbo数据传播特性扩展Filter接口来实现链路追踪的目的

重点主要是zipkin及brave使用及特性,当前brave版本为 5.2.0 为 2018年8月份发布的release版本 , zipkin版本为2.2.1 所需JDK为1.8

快速启动zipkin

下载最新的zipkin并启动

e2b470678e9ad4d587f3a9685a58f416.png

输入 http://localhost:9411/zipkin/ 进入WebUI界面如下

2b1c1074361e962ad1a2d6431d847ddc.png

核心源码

代码的初步版本:方便描述

8aa9a46730afee4bbcf589c83151d71b.png

51c239fc89214c348431b2d84715f6df.png

e62a95f34ba8b122f446a47d9b384527.png

271d448fd7a4b897c7f6df0e4a59020d.png

e40d089317dbaf455656134fe3baf55f.png

028911bbb9183ca1052a0923e36ef052.png

5e4bbfae49a7e28bc9a1252871432fb7.png

eec2c0a399a170fd79674114b874289f.png

927f7ad603eb0b1c9f25012eacf6325e.png

9f8bbe734f6fa8dee69f7f7c09338147.png

构建客户端发送工具

构建异步reporter

构建tracing上下文

初始化injector 和 Extractor [tab]4.1 extractor 指数据提取对象,用于在carrier中提取TraceContext相关信息或者采样标记信息到TraceContextOrSamplingFlags 中 -4.2 injector 用于将TraceContext中的各种数据注入到carrier中,其中carrier一半是指数据传输中的载体,类似于Dubbo中Invocation中的attachment(附件集合)

判断此次调用是作为服务端还是客户端

rpc客户端调用会从ThreadLocal中获取parent的 TraceContext ,为新生成的Span指定traceId及 parentId如果没有parent traceContext 则生成的Span为 root span

将Span绑定的TraceContext中 属性信息 Copy 到 Invocation中达到远程参数传递的作用

rpc服务提供端 , 从invocation中提取TraceContext相关信息及采样数据信息

生成span , 兼容初次服务端调用

记录接口信息及远程IP Port

将创建的Span 作为当前Span (可以通过Tracer.currentSpan 访问到它) 并设置查询范围

oneway调用即只请求不接受结果

如果future不为空则为 async 调用 在回调中finish span

设置异步回调,回调代码执行span finish() .

oneway调用 因为不需等待返回值 即没有 cr (Client Receive) 需手动flush()

同步调用 业务代码执行完毕后需手动finish()

设置枚举类 与 Dubbo中RpcException保持对应

测试项

Dubbo sync async oneway 测试

RPC异常测试

普通业务异常测试

并发测试

配置方式

POM依赖添加

86ea66612609a49ff05b85d5ee261aa7.png

资源目录根路径下添加tracing.properties文件

64f98b1a643c57341894591489088089.png

一次调用信息

df1290ed82e4b3c67300199c2182b556.png

调用链

258668e30d4ef6c5f86d7373fd0a1e36.png

调用成功失败汇总

87583d30c71630e88550fd66f794ac5f.png

zipkinHost 指定zipkin服务器IP:PORT 默认为localhost:9411 serviceName 指定应用名称 默认为trace-default

调用链:

a34463b9cb62a19d15e858eb085edf85.png

待扩展项

抽象数据传输(扩展Kafka数据传输)

调用返回值数据打印

更灵活的配置方式

源码地址

https://github.com/ZhuBaker/Tracing

送书啦!

参与活动↓↓↓↓↓

就有机会活动精美图书一本

5545e70831ef5657930b39c004e5fb42.png

活动时间:18日-23日

快来参与吧!

3e9b23f4bec2c06b5cebb1f3fa0aa6ed.gif

bb1c87f382cf3e69a6199a580afbeebb.png

点击“阅读原文”查看更多精彩内容

7c7e775597605db51c8bd1cc28c4fb70.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值