0

0

什么是 Jaeger,如何追踪 .NET 微服务?

煙雲

煙雲

发布时间:2025-09-30 12:20:04

|

963人浏览过

|

来源于php中文网

原创

答案:Jaeger是CNCF维护的分布式追踪系统,通过OpenTelemetry集成到.NET微服务中,采集请求链路数据并发送至Jaeger Agent,经Collector存储后可在UI查看调用链、延迟等信息。

什么是 jaeger,如何追踪 .net 微服务?

Jaeger 是由 Uber 开源、现由 Cloud Native Computing Foundation(CNCF)维护的分布式追踪系统,用于监控和诊断微服务架构中的请求链路。它能帮助开发者可视化服务之间的调用关系、识别性能瓶颈,比如慢请求、服务依赖问题等。

Jaeger 的核心组件

Jaeger 包含几个关键部分:

  • Jaeger Agent:运行在每台主机上的网络守护进程,接收来自客户端的追踪数据并转发给 Collector。
  • Jaeger Collector:接收上报的追踪信息,校验并写入后端存储(如 Elasticsearch 或 Cassandra)。
  • Query Service:提供 UI 查询接口,用于查看和搜索追踪记录。
  • UI(Jaeger UI):图形化界面,展示调用链、服务依赖图和延迟分布。

在 .NET 微服务中集成 Jaeger

要在 .NET 应用中实现分布式追踪,通常使用 OpenTelemetry 配合 Jaeger Exporter。OpenTelemetry 是统一的观测性框架,支持多种语言,.NET 生态中已广泛采用。

以下是具体步骤:

1. 安装必要 NuGet 包

在你的 .NET 项目中安装以下包:

  • OpenTelemetry
  • OpenTelemetry.Exporter.Jaeger
  • OpenTelemetry.Extensions.Hosting(如果是 ASP.NET Core 项目)
  • OpenTelemetry.Instrumentation.AspNetCore(可选,自动追踪 HTTP 请求)
  • OpenTelemetry.Instrumentation.Http(可选,追踪 HttpClient 调用)
dotnet add package OpenTelemetry --version 1.8.1 dotnet add package OpenTelemetry.Exporter.Jaeger --version 1.8.1 dotnet add package OpenTelemetry.Extensions.Hosting dotnet add package OpenTelemetry.Instrumentation.AspNetCore dotnet add package OpenTelemetry.Instrumentation.Http

2. 配置 OpenTelemetry 和 Jaeger Exporter

Program.cs 中添加如下配置(以 .NET 6+ 为例):

PageOn
PageOn

AI驱动的PPT演示文稿创作工具

下载
var builder = WebApplication.CreateBuilder(args); // 添加 OpenTelemetry 追踪服务 builder.Services.AddOpenTelemetryTracing(tracerProviderBuilder => { tracerProviderBuilder .AddAspNetCoreInstrumentation() // 自动追踪 MVC/WebAPI 请求 .AddHttpClientInstrumentation() // 自动追踪 HttpClient 调用 .AddJaegerExporter(opt => { opt.AgentHost = "localhost"; // Jaeger Agent 地址 opt.AgentPort = 6831; // 默认 UDP 端口 }) .SetResourceBuilder(ResourceBuilder.CreateDefault().AddService("MyDotNetService")); }); var app = builder.Build(); app.MapGet("/", () => "Hello World!"); app.Run();

这段代码会自动收集进入和离开服务的 HTTP 请求,并通过 Jaeger Exporter 发送到本地的 Jaeger Agent。

3. 启动 Jaeger 实例(开发环境

使用 Docker 快速启动 Jaeger All-in-One:

docker run -d --name jaeger \ -e COLLECTOR_ZIPKIN_HOST_PORT=:9411 \ -p 5775:5775/udp \ -p 6831:6831/udp \ -p 6832:6832/udp \ -p 5778:5778 \ -p 16686:16686 \ -p 14268:14268 \ -p 14250:14250 \ -p 9411:9411 \ jaegertracing/all-in-one:latest

启动后访问 https://www.php.cn/link/13941bddb1399810f387f38dc7c775f0 即可打开 Jaeger UI。

4. 验证追踪数据

运行你的 .NET 微服务,发起一些请求(例如访问 /api/values)。然后打开 Jaeger UI,选择对应的服务名称(如 MyDotNetService),点击 “Find Traces”,就能看到请求链路详情,包括每个 span 的耗时、标签、事件等。

进阶建议

  • 在生产环境中,建议将 Jaeger Collector 暴露为独立服务,并配置 TLS 和认证。
  • 可以结合日志系统(如 Serilog)将 TraceId 输出到日志,便于关联排查。
  • 若服务间使用 gRPC 或消息队列(如 Kafka),可分别启用 Grpc.Net.ClientOpenTelemetry.Instrumentation.Kafka 等插件增强追踪能力。
基本上就这些。只要配置好 OpenTelemetry 并连接到 Jaeger,.NET 微服务的调用链就能自动被捕捉和展示。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

326

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

233

2023.10.07

kafka消费者组有什么作用
kafka消费者组有什么作用

kafka消费者组的作用:1、负载均衡;2、容错性;3、广播模式;4、灵活性;5、自动故障转移和领导者选举;6、动态扩展性;7、顺序保证;8、数据压缩;9、事务性支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

167

2024.01.12

kafka消费组的作用是什么
kafka消费组的作用是什么

kafka消费组的作用:1、负载均衡;2、容错性;3、灵活性;4、高可用性;5、扩展性;6、顺序保证;7、数据压缩;8、事务性支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

149

2024.02.23

rabbitmq和kafka有什么区别
rabbitmq和kafka有什么区别

rabbitmq和kafka的区别:1、语言与平台;2、消息传递模型;3、可靠性;4、性能与吞吐量;5、集群与负载均衡;6、消费模型;7、用途与场景;8、社区与生态系统;9、监控与管理;10、其他特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

201

2024.02.23

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1027

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

66

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

455

2025.12.29

excel表格操作技巧大全 表格制作excel教程
excel表格操作技巧大全 表格制作excel教程

Excel表格操作的核心技巧在于 熟练使用快捷键、数据处理函数及视图工具,如Ctrl+C/V(复制粘贴)、Alt+=(自动求和)、条件格式、数据验证及数据透视表。掌握这些可大幅提升数据分析与办公效率,实现快速录入、查找、筛选和汇总。

0

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 9万人学习

ASP 教程
ASP 教程

共34课时 | 3.8万人学习

Python 教程
Python 教程

共137课时 | 7.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号