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 =><br>  tracerProviderBuilder<br>    .AddAspNetCoreInstrumentation() // 捕获 HTTP 入口(含 gRPC over HTTP/2)<br>    .AddGrpcClientInstrumentation() // 自动注入 client 端 span<br>    .AddOtlpExporter(opt => opt.Endpoint = new Uri("http://localhost:4317")); // 推送到 OTLP

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

HaiSnap
HaiSnap

一站式AI应用开发和部署工具

下载

手动创建 Span 关联业务逻辑

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

  • 通过 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);<br>try {<br>  var user = await _userRepository.GetByIdAsync(request.Name);<br>  dbSpan.SetAttribute("user.found", user != null);<br>} finally {<br>  dbSpan.End();<br>}

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

仅服务端埋点只能看到入向请求;要串联 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,就能可视化查看延迟瓶颈、错误分布和上下游依赖关系。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

402

2023.08.11

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

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

249

2023.10.07

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

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

252

2023.09.22

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

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

988

2024.03.01

Golang channel原理
Golang channel原理

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

257

2025.11.14

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

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

350

2025.11.17

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

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

381

2023.06.29

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

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

2105

2023.08.14

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

23

2026.03.03

热门下载

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

精品课程

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

共32课时 | 5.8万人学习

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

共10课时 | 0.9万人学习

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

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