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

news2024/7/6 19:08:51

微服务中链路追踪作用


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
  • 这里只进行简单的处理演示,如需要更详细的挂载,自行配置

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1595251.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

简历上写熟悉Linux下常用命令?直接寄

大家写简历技术栈时,都觉得越多越好,其中一条,熟悉Linux下常用命令?其实开发中Linux不是必备考点,除了运维,真正用的多的仅仅cd ls mkdir等,但当面试官问到上面命令时,是不是就傻眼了…

Java开发从入门到精通(二十):Java的面向对象编程OOP:Stream流

Java大数据开发和安全开发 (一)Java的新特性:Stream流1.1 什么是Stream?1.2 Stream流的使用步骤1.3 获取Stream流1.4 Stream流常见的中间方法1.5 Stream流常见的终结方法 (一)Java的新特性:Stream流 1.1 …

【Vue】面试题

vue的组建通信方式 父子关系:props & $emit 、 $parent / $children 、 ref / $refs 、 插槽跨层级关系: provide & inject通用方案:Vuex 或 eventbus 插播:兄弟组建怎么通信? eventbusVuex通过中间件&…

学校4-11天梯赛选拔赛

目录 L1-5 6翻了 题目 输入格式: 输出格式: 输入样例: 输出样例: 思路 AC代码 L1-1 嫑废话上代码 题目 输入格式: 输出格式: 输入样例: 输出样例: AC代码 L1-8 刮刮彩…

温故知新之-TCP Keepalive机制及长短连接

[学习记录] 前言 TCP连接一旦建立,只要连接双方不主动 close ,连接就会一直保持。但建立连接的双方并不是一直都存在数据交互,所以在实际使用中会存在两种情况:一种是每次使用完,主动close,即短连接&…

建模设计软件 Archicad 27 for mac激活版

在建筑设计领域,每一次技术的革新都意味着设计效率和质量的飞跃。Archicad 27 for Mac,就是这样一款引领行业变革的设计软件。 Archicad 27凭借出色的性能优化和强大的功能更新,为Mac用户带来了前所未有的建筑设计体验。它支持BIM&#xff08…

5G网络开通与调测ipv4

要求如下: 1. 勘站规划 1. 【重】首先观察NR频点,完成设备选型 2645--选择N41 3455--选择N78 4725--选择N79 设备选型如下:观察AAU的通道数,最大发射功率;选择N41的选型频段也要选41 2. …

InnoDB中高度为3的B+树最多可以存多少数据?

参考: 🔥我说MySQL每张表最好不超过2000万数据,面试官让我回去等通知? - 掘金 考虑到磁盘IO是非常高昂的操作,计算机操作系统做了预读的优化,当一次IO时,不光把当前磁盘地址的数据,…

sudo apt install ros-humble-gazebo-*显示网络不可达 Ubuntu20.04使用清华镜像本地安装/更新ros2

问题 sudo apt install ros-humble-gazebo-*显示网络不可达,这是因为sources.list中的镜像源有问题,换成清华源可以解决问题 解决 1 设置Ubuntu镜像源为清华镜像源 1.1 备份source.list文件 sudo cp /etc/apt/sources.list /etc/apt/sources.list.ba…

GNU Radio创建Zadoff-Chu序列C++ OOT块

文章目录 前言一、ZC序列是什么?二、创建自定义的 C OOT 块1、创建 OOT 模块2、创建 OOT 块3、修改 C 文件4、编译及安装 OOT 块 三、测试1、grc 图2、运行结果①、时域图②、时域幅值模图③、IQ 曲线 四、其他五、资源自取 前言 本文实现在 GNU Radio 中创建 Zado…

连接两部VR头显的type-c DP分配器方案,可以给主机设备PD反向供电与两部VR同时供电。

随着type-c的发展,目前越来越多的设备都在使用type-c作为连接的接口, 不仅是笔记本与手机在使用现在的游戏主机如(任天堂,steam,)或者是VR的一体机或者是VR头显也都在使用type-c作为连接接口。 type-c接口…

CSS常用十大选择器(理论+代码实操)

HTML代码实例 注意&#xff1a;拷贝后本地运行注意head标签中的link标签的href属性是否正确 我的目录结构&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><title>Title</title><lin…

使用新一代一站式 AI Bot 开发平台扣子coze,搭建我的第一个AI Bot(前端魔法师) ,

目录 1.概述​ 2.功能与优势 3.使用扣子 4.人设与回复逻辑 5.添加插件 6.预览与调试 7.发布bot Store 8.环境大家体验&#xff08;给大家内置了比较屌的插件&#xff09; 9.推荐阅读&#xff1a; 1.概述​ 扣子是新一代一站式 AI Bot 开发平台。无论你是否有编程基础…

代码学习记录42---动态规划

随想录日记part42 t i m e &#xff1a; time&#xff1a; time&#xff1a; 2024.04.14 主要内容&#xff1a;今天开始要学习动态规划的相关知识了&#xff0c;今天的内容主要涉及&#xff1a;最长递增子序列 &#xff1b;最长连续递增序列 &#xff1b;最长重复子数组 ;最长公…

陇剑杯 ios 流量分析

陇剑杯 ios 流量分析 ios 一位ios的安全研究员在家中使用手机联网被黑&#xff0c;不仅被窃密还丢失比特币若干&#xff0c;根据流量分析完成ios1-8 ios 1 ios-1&#xff1a;黑客所控制的C&C服务器IP是_____________。 什么是C&C服务器? C&C&#xff08;Com…

UBuntu18.04通过ODBC连接MySQL远程数据库

今天在做一个Qt视频播放器的小项目然后想要在ubuntu18.04运行这个项目&#xff0c;需要在Qt中连接远程的MySQL数据库&#xff0c;所以用到了ODBC。我在连接时遇到了一些问题&#xff0c;加之网上的教程各说纷纭&#xff0c;所以我花了很多时间去解决&#xff0c;所以决定做做笔…

架构师系列-搜索引擎ElasticSearch(五)- 索引设计

索引创建后&#xff0c;要非常谨慎&#xff0c;创建不好后面会出现各种问题。 索引设计的重要性 索引创建后&#xff0c;索引分片只能通过_split和_shrink 接口对其进行成倍的增加和缩减。 ES的数据是通过_routing分配到各个分片上的&#xff0c;所以本质上不推荐区改变索引的…

链表-双指针-虚拟节点-力扣

链表--双指针--虚拟节点 力扣 142 环形链表求循环起点 重点力扣 21 合并两个有序链表力扣 86 分割链表力扣23 合并K个有序链表 -- 优先队列&#xff08;二叉堆 小顶堆&#xff09;重点力扣19 找倒数第N个元素 快慢指针 一次遍历 重点力扣876 快慢指针找中间节点力扣 160 相交链…

vue简单使用三(class样式绑定)

目录 对象的形式绑定&#xff1a; 数组的形式绑定&#xff1a; 内联样式Style 对象的形式绑定&#xff1a; 可以看到class中有两个值 数组的形式绑定&#xff1a; 可以看到也有两个值 内联样式Style style样式设置成功 完整代码&#xff1a; <!DOCTYPE html> <html…

快速列表quicklist

目录 为什么使用快速列表quicklist 对比双向链表 对比压缩列表ziplist quicklist结构 节点结构quicklistNode quicklist 管理ziplist信息的结构quicklistEntry 迭代器结构quicklistIter quicklist的API 1.创建快速列表 2.创建快速列表节点 3.头插quicklistPushHead …