在 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客户端作为启动项目,然后运行,结果如下图所示:

参考资料

相关推荐
qq_479875435 小时前
X-Macros(1)
linux·服务器·windows
jun_bai7 小时前
python写的文件备份网盘程序
运维·服务器·网络
Warren987 小时前
Python自动化测试全栈面试
服务器·网络·数据库·mysql·ubuntu·面试·职场和发展
Eiceblue8 小时前
通过 C# 将 HTML 转换为 RTF 富文本格式
开发语言·c#·html
欢喜躲在眉梢里8 小时前
CANN 异构计算架构实操指南:从环境部署到 AI 任务加速全流程
运维·服务器·人工智能·ai·架构·计算
IUGEI8 小时前
synchronized的工作机制是怎样的?深入解析synchronized底层原理
java·开发语言·后端·c#
云飞云共享云桌面9 小时前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑
福尔摩斯张9 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
虚伪的空想家9 小时前
arm架构服务器使用kvm创建虚机报错,romfile “efi-virtio.rom“ is empty
linux·运维·服务器·javascript·arm开发·云原生·kvm
深藏bIue10 小时前
linux服务器mysql目录下的binlog文件删除
linux·服务器·mysql