ASP.NET Core GRPC 和 Dubbo 互通

ce5fb3ed93febeea3ab7ec4688cdcedf.png一.前言

Dubbo 是比较流行的服务治理框架,国内不少大厂都在使用。以前的 Dubbo 使用的是私有协议,采集用的 hessian 序列化,对于多语言生态来说是极度的不友好。现在 Dubbo 发布了新版本 v3,推出了基于 gRPC 的新协议 Triple,完全兼容 gRPC。目前和几个小伙伴正在探索 ASP.NET Core 接入 Dubbo 生态的可行性,本文算是一个先行测试。

Triple 协议说明:dubbo-go 3.0 新特性 | Apache Dubbo

ASP.NET Core GRPC: Overview for gRPC on .NET | Microsoft Learn

二.测试说明

Dubbo 使用的是 dubbo-go 项目提供的 samples apache/dubbo-go-samples: Apache dubbo (github.com),使用 direct 直连例子。

ASP.NET Core Grpc 基于 .NET 5。

分别作为 client 和 server 来测试是否能相互调用。

三.测试一

dubbo-go 作为 client 通过 tri 协议调用,ASP.NET Core 作为 Server。

1.ASP.NET Core

直接根据模板新建一个 Grpc 项目

3f7130124f89d2bb359071afa3dfa94e.png

因为我是 macOS 环境,目前 HTTP/2 无法支持 TLS,所以我配置了 Kestrel,不使用 TLS 启用 HTTP/2。

69036ac94c8ca8a7c832a8acf9a13c6d.png

2.同步 proto文件

在 go 项目找到 proto 文件,复制粘贴到 grpc 项目 greet.proto 文件里,并修改 csharp_namespace

946bb1a31e72129a1636de13b5c1290f.png

7ab41653a7f195c19aa114cf90a38469.png

然后编译 Grpc 修改 Service 代码

ade5f5bb3d495a29999100a6affe0ce7.png

3.dubbo-go 调用

修改 dubbo-go client 调用地址端口号为 5000

958c8cd8f3ddd8c9c8d713a808ac24f8.png

然后运行 client

a54e13892ebb789e7e0dbf82393f723d.png

从日志输出我们可以看到成功进行了调用

dubbo-> asp.net core grpc = ok

四.测试二

dubbo-go 作为 server tri 协议,.NET 作为 Client grpc 调用。

1.dotnet

新建一个控制台项目,安装 3 个 nuget 包:

包名说明
Grpc.Net.Client.NET 客户端
Google.Protobufprotobuf api
Grpc.Tools支持 proto 文件生成 C# 代码

编辑项目文件 .csproj

加入 proto 文件引用

<ItemGroup>
        <Protobuf Include="..\GrpcService1\Protos\greet.proto" GrpcServices="Client" />
</ItemGroup>

编译时 Grpc.Tools 会根据 proto 文件生成 grpc C# client。生成路径:obj\Debug\[TARGET_FRAMEWORK]\Protos\Greet.cs

eff93f646c88762dd7504d350adc395a.png

编写 client 调用代码

static async Task Main(string[] args)
{
    using var channel = GrpcChannel.ForAddress("https://localhost:20000");
    var client = new Greeter.GreeterClient(channel);
    var reply = await client.SayHelloAsync(
        new HelloRequest { Name = "GreeterClient" });
    Console.WriteLine($"Reply: Age: {reply.Age}, Id: {reply.Id}, Name: {reply.Name}");
}

2.go

直接运行 server

f4438d2a2e49bdd6b2fbd71f78b30742.png

3.运行测试

28d1a3af63a598eb94385bbb1a1680a5.png

从日志输出我们可以看到成功进行了调用

dotnet-> dubbo = ok

五.总结

从上面测试,我们确定了 ASP.NET Core 结合 Grpc 接入 Dubbo 生态,和 dubbo 互通的可能性,我们也在积极的朝这一方向进行努力(大家都比较忙,推进慢)。

.NET Core是微软开源的跨平台框架,可以用于构建Web应用程序、Web API、微服务和其他类型的应用程序。gRPC是一种高性能、开源的远程过程调用(RPC)框架,它使用Protocol Buffers作为序列化协议。 在.NET Core中,可以使用gRPC框架来构建高性能、跨平台的微服务。gRPC框架提供了基于Protocol Buffers的定义和代码生成工具,使得开发人员可以轻松地定义和实现RPC接口。gRPC框架还提供了基于HTTP/2的双向流式传输,这意味着客户端和服务器可以同时发送和接收多个消息,从而提高了系统的吞吐量和性能。 使用gRPC框架开发微服务的步骤如下: 1. 定义gRPC服务:使用Protocol Buffers定义接口和消息类型。 2. 生成代码:使用gRPC工具生成客户端和服务器端代码。 3. 实现服务:实现服务器端接口。 4. 创建客户端:创建gRPC客户端并调用服务。 .NET Core提供了丰富的工具和库来支持gRPC开发,包括: 1. gRPC工具:可以使用gRPC工具从Protocol Buffers文件生成代码。 2. gRPC.AspNetCore:可以使用gRPC.AspNetCore库在ASP.NET Core应用程序中托管gRPC服务。 3. gRPC.Net.Client:可以使用gRPC.Net.Client库创建gRPC客户端。 4. gRPC.Tools:可以使用gRPC.Tools库在Visual Studio中集成gRPC工具。 总之,.NET Core提供了完整的支持gRPC的框架和工具,使得开发人员可以轻松地构建高性能、跨平台的微服务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值