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

相关文章

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

高并发环境中保持幂等性

在高并发环境中保持幂等性是一项重要的挑战。幂等性指的是无论操作执行多少次,其效果都是相同的。确保操作的幂等性可以避免重复执行带来的副作用。以下是一些保持幂等性的常用方法: 唯一标识符: 请求唯一标识:在每次请求中引入唯一标识符(如 UUID 或者生成的唯一 ID),在处理请求时,系统可以检查这个标识符是否已经处理过,如果是,则忽略重复请求。幂等键(Idempotency Key):客户端在每次

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

pico2 开发环境搭建-基于ubuntu

pico2 开发环境搭建-基于ubuntu 安装编译工具链下载sdk 和example编译example 安装编译工具链 sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib 注意cmake的版本,需要在3.17 以上 下载sdk 和ex