在 C#和ASP.NET Core中创建 gRPC 客户端和服务器

关于gRPC和Google protobuf

gRPC 是一种可以跨语言运行的现代高性能远程过程调用 (RPC) 框架。gRPC 实际上已经成为 RPC 框架的行业标准,Google 内外的组织都在使用它来从微服务到计算的"最后一英里"(移动、网络和物联网)的强大用例。
gRPC是一个高性能的开源的通用RPC框架,由Google公司开发,支持常用的C++、Java、Python、C#/.Net、Go、Node、Dart、Kotlin、Object-C、PHP、Ruby等语言,采用protobuf作为数据交换格式,并且采用C++开发,支持Windows 、Linux、macOS跨平台开发。对于跨语言服务调用非常方便,只要使用protobuf定义接口协议,然后按照gRPC语言SDK调用即可。比如我们使用C++对环保数采仪器设备通过串口或者网口传送的数据协议如Modbus协议、HJ212协议、或者厂商自定义的协议进行解析之后,将数据存放到本地数据库,这个时候我们如何将C++的数据传给前端网页呢?

这个时候可以使用多种方式。比如通过数据库、HTTP协议、WebSocket协议、RPC远程过程调用等方式。

我之前做环保的时候,采用C++和环保硬件设备打交道,通过C++后台程序将数采仪数据解析之后存入到本地Sqlite数据库中(分表分页存储),然后由于展示的网页比较简单,只是用网页展示当前站点的数据,前端采用ElementUI和Vue.js,后端采用Node.js。另外,C++后台写了一套RPC服务端接口,Node.js通过RPC客户端调用C++的后台RPC服务,双方之间通过Google Protobuf数据协议交互。

在 gRPC 中,客户端应用程序可以像本地对象一样直接调用不同机器上的服务器应用程序上的方法,从而使您更轻松地创建分布式应用程序和服务。与许多 RPC 系统一样,gRPC 基于定义服务的思想,指定可以远程调用的方法及其参数和返回类型。在服务器端,服务器实现这个接口并运行一个gRPC服务器来处理客户端调用。在客户端,客户端有一个存根(在某些语言中简称为客户端),它提供与服务器相同的方法。

gRPC 客户端和服务器可以在各种环境中运行和相互通信(从 Google 内部的服务器到您自己的桌面),并且可以用 gRPC 支持的任何语言编写。例如,您可以使用 Java 轻松创建 gRPC 服务器,并使用 Go、Python 或 Ruby 编写客户端。此外,最新的 Google API 将具有其接口的 gRPC 版本,让您可以轻松地将 Google 功能构建到您的应用程序中。

在 C#和ASP.NET Core中创建 gRPC 客户端和服务器

在 C#和ASP.NET Core中创建 gRPC 客户端和服务器十分简单,可以参考微软官方的几篇文章:

对应在VS2022中分别运行GRPC服务端和客户端的SayHello示例接口调用如下图所示:

C# 中的 gRPC 简介视频教程

另外,油管上面有来自UP主IAmTimCorey于2019年9月30日创作的一篇关于C#中使用GRPC的视频,地址为:Intro to gRPC in C# - How To Get Started

相关示例代码我已经上传到我的Github仓库,地址为:https://github.com/ccf19881030/GrpcGreeterDemo

我们git clone https://github.com/ccf19881030/GrpcGreeterDemo.git 源代码到本地后,使用VS2022打开GrpcGreeterDemo.sln解决方案,里面有GrpcGreeterGrpcGreeterClient两个项目,分别是基于ASP.Net Core的gRPC服务端程序和基于.NetCore控制台的gRPC客户端程序,我的VS2022使用的是.NetCore 7.0。如下图所示:

我们首选将GrpcGreeter gRPC服务端程序作为启动项目,然后运行,如下图所示:

接着我们再将GrpcGreeterClient gRPC客户端作为启动项目,然后运行,结果如下图所示:

参考资料

相关推荐
松涛和鸣3 小时前
32、Linux线程编程
linux·运维·服务器·c语言·开发语言·windows
sali-tec3 小时前
C# 基于halcon的视觉工作流-章69 深度学习-异常值检测
开发语言·图像处理·算法·计算机视觉·c#
我是唐青枫3 小时前
深入理解 C#.NET 运算符重载:语法、设计原则与最佳实践
开发语言·c#·.net
Lv11770083 小时前
Visual Studio中的字典
ide·笔记·c#·visual studio
Xの哲學3 小时前
Linux NAT 深度剖析: 从设计哲学到实现细节
linux·服务器·网络·架构·边缘计算
Dxy12393102164 小时前
Python的正则表达式入门:从小白到能手
服务器·python·正则表达式
小周学学学4 小时前
vSphere DRS与vSphere HA
运维·服务器·vmware·虚拟化
德迅云安全—珍珍4 小时前
主机安全-德迅卫士
linux·服务器·安全
咕噜企业分发小米4 小时前
如何平衡服务器内存使用率和系统稳定性?
java·服务器·前端
2301_805962934 小时前
Windows连接腾讯云服务器
服务器·windows·腾讯云