对GRPC的通用封装

对GRPC的通用封装,第1张

通过封装将grpc的技术使用难度降低到普通Java程序的开发。
cncomydcommonsgrpc提供了4种形式的服务接口定义以适应不同的应用场景。
cncomydcommonsgrpc将请求参数和响应参数定义为bytes以统一因业务不同而导致的差异性;使用cglib进行动态代理,在grpc的方法中执行具体的业务处理。
在具体应用中应将此工程使用Maven打包后作为依赖引入目标工程中。

JDK:18
GRPC:161
Protobuf:330
cglib:325
IDE:开发工具IDEA

IDEA自带插件支持grpc开发,所以开发工具选择IDEA。在正式开始之前需要先安装Protobuf Support插件。
依次点击Intellij中的“File”-->"Settings"-->"Plugins"-->"Browse repositories",如图

输入Protobuf,如下所示

在main目录下新建一个名为proto的文件夹,请确保文件夹的所处位置以及名称都正确,否则将不能进行编译,而且不报任何错误。

proto文件编写完成后进行编译以生成对应的class文件,编译后的效果大致如图

其中包含了Request、Response与JSONObject之间的转换等,主要是对应用的辅助。

暂不公开。

Pub/Sub 和 gRPC 是两种不同的网络通信技术。
Pub/Sub(发布/订阅)是一种分布式消息传递模型,允许生产者发布消息到主题,消费者订阅主题以接收消息。这种模型通常用于异步通信场景,以便在生产者和消费者之间实现松散耦合。
gRPC 是一种基于 Protocol Buffers 的高效的远程过程调用(RPC)框架。它支持多种语言,并具有高效的序列化、加密和压缩功能。gRPC 用于实现同步的客户端/服务器通信,通常用于微服务架构中的服务间通信。
总的来说,Pub/Sub 和 gRPC 在不同的通信场景中都有各自的优势。

NET 7 正式推出标准期限支持,支持期限为 18 个月。 其中包括许多令人兴奋的新功能,包括 Web API、gRPC、ASPNET 和 C#11 的性能升级。
本文涵盖以下主题:
NET 7 中的性能改进。
gRPC JSON 转码。
在 NET 7 中创建 gRPC 服务。
在 Postman 使用 gRPC 服务。
使用服务器反射和 Postman
添加 Swagger 规范。
除了讨论 NET 7 中 gRPC 的新特性,我们还将实现一个能够在一分钟内流式传输 500 万条记录的真实微服务。
这是一个快速回顾:
gRPC 是由 CNCF 开发的流行的开源 RPC 框架。
作为契约优先、独立于语言的框架,客户端和服务器必须就消息的内容和传递方式达成一致,契约在 proto 文件中定义,然后使用 NET7 的工具生成代码。
在单个 tcp 连接上,>rpc调用原理框架如图:

-支持多语言的rpc框架,例如Google的grpc,facebook thrift, 百度的brpc
-支持特定语言的rpc框架, 例如新浪微博的Motan
-支持服务治理微服务化特性框架,其底层仍是rpc框架,例如 阿里的Dubbo
目前业内主要使用基于多语言的 RPC 框架来构建微服务,是一种比较好的技术选择,例如netflix ,API服务编排层和后端微服务之间采用微服务rpc进行通信

-支持C java js
-git地址 >手机显示grpc通道连接成功的意思是:能够被远程调用的方法,包含参数和返回类型。手机grpc在服务端实现这个接口,并运行一个grpc服务器来处理客户端调用,在客户端拥有一个stub连接服务端上的方法,grpc可提供高效的进程间通信,具有简单且定义良好的服务接口、支持多语言、支持双工流、具备内置的商业化特性与云原生生态进行了集成。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/13285834.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-07-08
下一篇 2023-07-08

发表评论

登录后才能评论

评论列表(0条)

保存