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

Jaeger 是由 Uber 开源、现由 Cloud Native Computing Foundation(CNCF)维护的分布式追踪系统,用于监控和诊断微服务架构中的请求链路。它能帮助开发者可视化服务之间的调用关系、识别性能瓶颈,比如慢请求、服务依赖问题等。
Jaeger 包含几个关键部分:
要在 .NET 应用中实现分布式追踪,通常使用 OpenTelemetry 配合 Jaeger Exporter。OpenTelemetry 是统一的观测性框架,支持多种语言,.NET 生态中已广泛采用。
以下是具体步骤:
在你的 .NET 项目中安装以下包:
OpenTelemetryOpenTelemetry.Exporter.JaegerOpenTelemetry.Extensions.Hosting(如果是 ASP.NET Core 项目)OpenTelemetry.Instrumentation.AspNetCore(可选,自动追踪 HTTP 请求)OpenTelemetry.Instrumentation.Http(可选,追踪 HttpClient 调用)在 Program.cs 中添加如下配置(以 .NET 6+ 为例):
这段代码会自动收集进入和离开服务的 HTTP 请求,并通过 Jaeger Exporter 发送到本地的 Jaeger Agent。
使用 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。
运行你的 .NET 微服务,发起一些请求(例如访问 /api/values)。然后打开 Jaeger UI,选择对应的服务名称(如 MyDotNetService),点击 “Find Traces”,就能看到请求链路详情,包括每个 span 的耗时、标签、事件等。
Grpc.Net.Client 和 OpenTelemetry.Instrumentation.Kafka 等插件增强追踪能力。以上就是什么是 Jaeger,如何追踪 .NET 微服务?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号