本文主要是介绍(六)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按钮来查询刚刚的链路请求,如下图:
这篇关于(六)go-kit集成jaeger实现服务链路追踪的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!