(六)go-kit集成jaeger实现服务链路追踪

前言

微服务架构是一个分布式架构,实际开发中,我们按照业务要求划分服务单元,一套系统往往由多个业务单元构成。在这个场景中,一个请求肯能要经历多个业务单元的处理才能完成响应,如果出现了异常或者错误,很难定位。在往常的查询中我们往往会采取查询日志的办法定位问题,这种方法是个办法,但不是个好办法,我们需要一件工具来解放自己,在这种背景下就可以引入我们的链路追踪工具。
本文代码地址: github地址

安装jaeger

通过docker安装jaeger环境:sudo docker run -d -e COLLECTOR_ZIPKIN_HTTP_PORT=9411 -p5775:5775/udp -p6831:6831/udp -p6832:6832/udp -p5778:5778 -p16686:16686 -p14268:14268 -p9411:9411 jaegertracing/all-in-one:latest,能正常访问 http://127.0.0.1:16686/ 则安装成功

Metric中间件

然后代码和metric的套路是一样的,这里在/cell-trace/register/middleware/trace.go里面实现一个中间件Metric用来在main函数里面后面装饰IUserService接口,同时这里实现IUserService的几个方法

集成到main函数里面

main.go的trace相关代码tracer, _, err := middleware.NewJaegerTracer("user_agent_server") if err != nil{ fmt.Println(err) } svc = middleware.NewTracerMiddleware(tracer)(svc)
然后这里需要在相关的方法里面都加上context,最后重启register服务

调试运行

然后在浏览器访问一次localhost:8000/user/1,在jaeger的后台里面可以通过Find Traces按钮来查询刚刚的链路请求,如下图:
在这里插入图片描述