Go微服务: 链路追踪jaeger原理和环境搭建

微服务中链路追踪作用

1 ) 概述

  • 著名的管理学大师彼得·德鲁克曾说过
  • "If you can't measure it, you can't improve it"
  • 意思是:如果你不能度量它,你就无法改进它
  • 在微服务开发后期,服务会越来越多,调用链过多,进行链路追踪时,心态会崩溃
  • 这时候,我们就要引入一个链路跟踪的工具:jaeger
  • jaeger 是用来监视和诊断基于微服务的分布式系统
  • 用于服务依赖性分析,辅助性能优化
  • 里面反应出来依赖关系之间的调用时间 (开始和结束时间)

2 )jaeger 主要特性

  • 高扩展性
    • 微服务分布式系统在生产过程中,要求稳定性非常高
    • 链路追踪也要求稳定性非常的高,在设计的时候,就排除了单点故障
    • 可以根据业务需求,按需扩展
  • 原生支持 OpenTracing
    • 它是一个标准
  • 可观察性
    • jaeger 不仅是收集和存储数据
    • 还提供了数据查询和展示
    • 可观察性在微服务中提供排错
    • 选择组件的时候,也要考虑组件是否具有可观察性

微服务链路追踪(jaeger) - 术语 Span

  • Jaeger 中的逻辑工作单元
  • 具有操作名称,操作的时间和持续时间
  • 跨度可以嵌套并排序以建立因果关系模型
    • 告诉a和b,它们之间是怎么调用的
    • 它们中间怎么调用 c 的,中间使用了多长时间
    • 这些都反映在链路追踪里面去

微服务链路追踪(jaeger) - 术语 Span 包含的对象

  • Operation name: 操作名称 (也可以称作 Span name)
  • Start timestamp: 其实时间
  • Finish timestamp: 结束时间
  • Span tag: 一组键值对构成的 Span 标签集合
  • Span log: 一组 Span 日志集合
  • SpanContext: span 上下文对象
  • References (Span 间关系):相关零个或多个Span

微服务链路追踪 (jaeger) 调用原理

1 )示例

  • user 在调用服务时,首先发送一个请求到 A
  • A 这里相当于一个接口或代理,它一旦发现 user调用,根据请求路由等
  • 发现需要先查询服务B和C,在调用到服务C的时候,C又需要依赖D和E的服务等等

2 )一次调用链分析

  • 这个映射到链路追踪中,就是一次调用链的分析
  • 通过这个调用链分析,还可以抽象出一个时间轴
  • 这里 Span A 包含 Span B 和 Span C
  • Span B 依赖 Span D, Span C 依赖 Span E 和 Span F, Span F 依赖 Span G
  • 在图里,调用C的时候,C下面所有依赖都结束的时候,C才会结束

jaeger的原理 - 它的组件们

  • 蓝色部分都是它的组件
  • 第一个组件是 jaeger-client
    • 它由不同的语言组成,go, java, ...
    • client 里包含 trace 信息之后,会发送到 agent 里面
  • 第二个组件是 jaeger-agent, 代理是解耦它们之间关系的
    • 代理再把消息发送到 collector 这端
  • 第三个组件是 jaeger-collector
    • 数据收集完以后,存储到 Data Store (Cassandra) 数据库中
    • 这个数据从产生,搜集到 存储就是上图所示关系
    • 展示的时候,通过数据库把数据展示出去的
  • 第四和第五的展示组件: jaeger-ui(React), jaeger-query(Go)
  • 下图这是 Jaeger client library 组件
  • 黄色部分是使用代码控制的程序
  • 红色部分是 Instrumentation 操作
  • 就是把应用程序和 jaeger client 封装起来
  • 形成了从应用程序到jaeger里面的交互
  • 这边会包括 Headers 头,Trace ID

Jaeger 的五个重要组件

  • jaeger-client 客户端库
    • 这个在不同语言都有不同的库
  • agent 客户端代理
    • 主要是一个监听的守护程序
    • 用来接收client端发送的数据
    • 发送到 agent, agent 充当了数据接收
    • agent 会把接收到的数据发送到 Collector端
  • Collector 数据收集处理
    • 这样,agent 就充当了数据解耦的角色
  • Data Store 数据存储
    • 这里的 数据存储,可以换成自己想要的,比如 ES, Hadoop等
  • UI 数据查询和前端界面的展示
    • 通过数据存储,查询出数据并展示

jaeger 的端口说明

端口 协议 所属模块 功能
5775 UDP agent 通过兼容性Thrift协议, 接收Zipkin thrift类型数据
6831 UDP agent 通过兼容性Thrift协议, 接收Jaeger thrift类型数据
6832 UDP agent 通过兼容性Thrift协议, 接收Jaeger thrift类型数据
5778 HTTP agent 配置控制服务接口
16686 HTTP query 客户端前端界面展示端口
14267 HTTP collector 接收客户端Jaeger thrift类型数据
14268 HTTP collector 接收客户端Zipkin thrift类型数据
9411 HTTP collector Zipkin兼容endpoint
  • 5775, 6831, 6832 都是 UDP
  • 这些端口中,比较常用的就是 6831 和 16686
  • 一个是用于接收 jeager 数据,一个是客户端展示,查询界面
  • 端口根据需要来开启

链路追踪 jaeger的安装和运行

  • $ docker pull jaegertracing/all-in-one:latest
  • $ docker run -d --name jaeger -e COLLECTOR_ZIPKIN_HTTP_PORT=9411 -p 5775:5775/udp -p 6831:6831/udp -p 6832:6832/udp -p 5778:5778 -p 16686:16686 -p 14268:14268 -p 9411:9411 jaegertracing/all-in-one:latest
  • 这里只进行简单的处理演示,如需要更详细的挂载,自行配置
相关推荐
藥瓿亭3 分钟前
K8S认证|CKS题库+答案| 8. 沙箱运行容器 gVisor
linux·运维·docker·云原生·容器·kubernetes·cks
宇钶宇夕20 分钟前
电路图识图基础知识-电机顺序启动控制电路解析(二十二)
运维·自动化
Cxzzzzzzzzzz35 分钟前
Go语言堆内存管理
开发语言·后端·golang
网硕互联的小客服38 分钟前
如何排查 Docker 容器资源占用过高的问题?
运维·服务器·网络·安全·docker·容器
执笔为剑1 小时前
Linux系统部署KES
linux·运维·服务器
何双新1 小时前
Cursor+MCP编程工具助力开发效率倍增
中间件·golang·pycharm
bcxwz6692 小时前
linux 下常用变更-8
linux·运维·服务器
weixin_307779137 小时前
Clickhouse统计指定表中各字段的空值、空字符串或零值比例
运维·数据仓库·clickhouse
bubiyoushang8887 小时前
Windows11 WSL2 Ubuntu编译安装perf工具
linux·运维·ubuntu
xuanwojiuxin9 小时前
linux panic-propagation
linux·运维·服务器