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

2024-04-15 07:52

本文主要是介绍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 的端口说明


端口协议所属模块功能
5775UDPagent通过兼容性Thrift协议, 接收Zipkin thrift类型数据
6831UDPagent通过兼容性Thrift协议, 接收Jaeger thrift类型数据
6832UDPagent通过兼容性Thrift协议, 接收Jaeger thrift类型数据
5778HTTPagent配置控制服务接口
16686HTTPquery客户端前端界面展示端口
14267HTTPcollector接收客户端Jaeger thrift类型数据
14268HTTPcollector接收客户端Zipkin thrift类型数据
9411HTTPcollectorZipkin兼容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
  • 这里只进行简单的处理演示,如需要更详细的挂载,自行配置

这篇关于Go微服务: 链路追踪jaeger原理和环境搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/905252

相关文章

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

python常见环境管理工具超全解析

《python常见环境管理工具超全解析》在Python开发中,管理多个项目及其依赖项通常是一个挑战,下面:本文主要介绍python常见环境管理工具的相关资料,文中通过代码介绍的非常详细,需要的朋友... 目录1. conda2. pip3. uvuv 工具自动创建和管理环境的特点4. setup.py5.

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

Go语言中Recover机制的使用

《Go语言中Recover机制的使用》Go语言的recover机制通过defer函数捕获panic,实现异常恢复与程序稳定性,具有一定的参考价值,感兴趣的可以了解一下... 目录引言Recover 的基本概念基本代码示例简单的 Recover 示例嵌套函数中的 Recover项目场景中的应用Web 服务器中