0

0

Dapper在gRPC服务中怎么用 Dapper与gRPC结合实例

星降

星降

发布时间:2026-01-14 20:00:13

|

986人浏览过

|

来源于php中文网

原创

OpenTelemetry 是 .NET 中实现分布式追踪的标准方案,取代了已不维护的 Dapper 概念;通过 OpenTelemetry.Instrumentation.AspNetCore、GrpcNetClient 和 OTLP 导出器,结合 gRPC 拦截器,可自动采集端到端调用链。

dapper在grpc服务中怎么用 dapper与grpc结合实例

Dapper 是 Google 提出的分布式追踪系统理念,而实际在 .NET 生态中,“Dapper” 更常被误指为 OpenTelemetry(尤其是 .NET 的 OpenTelemetry.Trace 实现),因为原生 Dapper 已不维护,且 .NET 社区普遍用 OpenTelemetry 替代其实现链路追踪。gRPC 服务本身不内置追踪能力,需借助 OpenTelemetry + gRPC 拦截器(Interceptor)来实现端到端调用链采集。

为什么不是“Dapper”而是 OpenTelemetry?

.NET 中没有官方叫 “Dapper”的分布式追踪库;名字易混淆是因为:

  • “Dapper” 是 Google 2010 年论文提出的概念模型(如 trace/span/annotation),不是具体 SDK;
  • Microsoft 和 CNCF 推荐并深度集成的是 OpenTelemetry(OTel),它正是 Dapper 思想的现代开源实现;
  • gRPC .NET 官方文档和示例均基于 OpenTelemetry 构建追踪能力。

在 gRPC Server 中启用 OpenTelemetry 追踪

以 ASP.NET Core gRPC 服务为例,只需几处配置即可自动捕获 RPC 方法调用:

  • 安装 NuGet 包:OpenTelemetry.Instrumentation.GrpcNetClient(客户端)、OpenTelemetry.Instrumentation.AspNetCore(服务端 HTTP 层)、OpenTelemetry.Exporter.OpenTelemetryProtocol(导出到 Jaeger/Zipkin/OTLP 后端);
  • Program.cs 中注册追踪器:
(C# 示例)

builder.Services.AddOpenTelemetry().WithTracing(tracerProviderBuilder =>
tracerProviderBuilder
.AddAspNetCoreInstrumentation() // 捕获 HTTP 入口(含 gRPC over HTTP/2)
.AddGrpcClientInstrumentation() // 自动注入 client 端 span
.AddOtlpExporter(opt => opt.Endpoint = new Uri("http://localhost:4317")); // 推送到 OTLP

✅ 效果:每个 gRPC 方法(如 SayHello)会自动生成 span,包含 method、status、duration、peer.address 等属性。

手动创建 Span 关联业务逻辑

若需追踪方法内部耗时操作(如 DB 查询、HTTP 调用),可在 service 实现中手动添加上下文感知的 span:

MiniMax Agent
MiniMax Agent

MiniMax平台推出的Agent智能体助手

下载
  • 通过 System.Diagnostics.ActivitySource 创建自定义 span;
  • 或使用 TracerProvider.Current.GetTracer(...).StartActiveSpan(...)
  • 关键:确保 span 设置 SetParentId(Activity.Current?.Id) 维持链路连续性。

例如在 GreeterService.SayHello 中记录数据库查询:

(片段示意)

using var dbSpan = tracer.StartActiveSpan("db.query.users", ActivityKind.Internal);
try {
var user = await _userRepository.GetByIdAsync(request.Name);
dbSpan.SetAttribute("user.found", user != null);
} finally {
dbSpan.End();
}

客户端也需埋点才能形成完整链路

仅服务端埋点只能看到入向请求;要串联 client → server → downstream service,客户端 gRPC 调用也必须启用 OTel:

  • 创建 channel 时注入拦截器:GrpcChannel.ForAddress(..., new GrpcChannelOptions { Interceptors = { new OpenTelemetryInterceptor() } });
  • 确保 client 项目同样引用 OpenTelemetry.Instrumentation.GrpcNetClient 并注册;
  • 调用 stub.SayHelloAsync(...) 时,会自动携带 traceparent HTTP header,服务端自动解析并续接 span。

基本上就这些。不需要改业务代码结构,也不依赖特定框架——OpenTelemetry 是标准、轻量、可插拔的方案。只要 client/server 都开启 OTel + gRPC 拦截器,调用链就能自动串起来,再配上 Jaeger 或 Prometheus + Tempo,就能可视化查看延迟瓶颈、错误分布和上下游依赖关系。

相关专题

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

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

323

2023.08.11

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

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

231

2023.10.07

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

231

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

435

2024.03.01

Golang channel原理
Golang channel原理

本专题整合了Golang channel通信相关介绍,阅读专题下面的文章了解更多详细内容。

244

2025.11.14

golang channel相关教程
golang channel相关教程

本专题整合了golang处理channel相关教程,阅读专题下面的文章了解更多详细内容。

342

2025.11.17

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

344

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2074

2023.08.14

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 3.7万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

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

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