当前位置: 首页 > news >正文

gRPC 四模式之 双向流RPC模式

双向流RPC模式

在双向流 RPC 模式中,客户端以消息流的形式发送请求到服务器端,服务器端也以消息流的形式进行响应。调用必须由客户端发起,但在此之后,通信完全基于 gRPC 客户端和服务器端的应用程序逻辑。

为什么有了双向流模式,还要使用单向流模式?

虽然双向流模式非常强大,但并不是所有的场景都需要这种模式。客户端流、服务端流和双向流这三种模式各有其适用的场景。

  1. 客户端流模式:在这种模式下,客户端可以连续发送多个消息到服务器,但服务器只返回一个响应。这种模式适用于客户端需要上传大量数据,但服务器只需要返回一个结果的场景,例如文件上传。

  2. 服务端流模式:在这种模式下,客户端发送一个请求到服务器,然后服务器可以连续返回多个响应。这种模式适用于服务器需要返回大量数据,但客户端只发送一个请求的场景,例如数据下载。

  3. 双向流模式:在这种模式下,客户端和服务器都可以连续发送和接收消息。这种模式适用于需要实时交互的场景,例如聊天应用。

选择哪种模式取决于你的具体需求。如果你的应用只需要一方连续发送消息,那么客户端流或服务端流可能更适合。如果你的应用需要双方都可以连续发送和接收消息,那么双向流可能更适合。

c++ 的双向流模式的一个实现

在gRPC中,双向流模式的C++实现涉及到创建一个服务,该服务在.proto文件中定义,然后在服务器端和客户端实现。以下是一个简单的示例:

首先,我们在.proto文件中定义服务:

syntax = "proto3";service MyService {rpc MyMethod (stream MyRequest) returns (stream MyResponse) {}
}message MyRequest {// Your request fields here
}message MyResponse {// Your response fields here
}

然后,我们在服务器端实现这个服务:

class MyServiceImpl final : public MyService::Service {grpc::Status MyMethod(grpc::ServerContext* context, grpc::ServerReaderWriter<MyResponse, MyRequest>* stream) override {MyRequest request;while (stream->Read(&request)) {// Process the request and generate a responseMyResponse response;// Fill the responsestream->Write(response);}return grpc::Status::OK;}
};

最后,我们在客户端使用这个服务:

class MyClient {public:explicit MyClient(std::shared_ptr<grpc::Channel> channel): stub_(MyService::NewStub(channel)) {}void MyMethod() {grpc::ClientContext context;auto stream = stub_->MyMethod(&context);// Send requestsfor (int i = 0; i < 10; ++i) {MyRequest request;// Fill the requeststream->Write(request);}stream->WritesDone();// Receive responsesMyResponse response;while (stream->Read(&response)) {// Process the response}grpc::Status status = stream->Finish();if (!status.ok()) {// Handle the error}}private:std::unique_ptr<MyService::Stub> stub_;
};

代码分析
这是一个使用gRPC编写的C++客户端程序。程序中定义了一个名为MyClient的类,该类包含一个构造函数和一个名为MyMethod的成员函数。

构造函数接受一个std::shared_ptr<grpc::Channel>类型的参数,用于连接gRPC服务器。通过该参数,MyClient类可以创建一个MyService::Stub类型的对象,该对象用于调用gRPC服务器的MyMethod方法。

MyMethod函数用于调用gRPC服务器的MyMethod方法。首先,它创建一个grpc::ClientContext类型的对象context,然后使用stub_对象调用MyMethod方法,并将context作为参数传递。接下来,它创建一个MyRequest类型的对象request,并使用stream对象将其写入。然后,它使用循环向stream对象发送10个MyRequest类型的对象,直到完成。

接着,它使用stream对象读取响应,并将它们存储在MyResponse类型的对象response中。然后,它使用一个无限循环来处理这些响应,直到stream对象完成。最后,它使用stream对象获取完成状态,并检查是否发生错误。如果发生错误,它将调用grpc::Status::Status方法来获取错误信息,并调用grpc::Status::Status方法来处理错误。

总结起来,这是一个使用gRPC编写的C++客户端程序,用于调用gRPC服务器上的MyMethod方法,并将响应处理为MyResponse类型。


分享一个有趣的 学习链接:https://xxetb.xet.tech/s/HY8za

http://www.lryc.cn/news/236110.html

相关文章:

  • 五分钟,Docker安装kafka 3.5,kafka-map图形化管理工具
  • 2023.11.18html中如何使用input/button进行网页跳转
  • java文件压缩加密,使用流的方式
  • 月子会所信息展示服务预约小程序的作用是什么
  • Windows核心编程 静态库与动态库
  • 【Spring Boot】如何自定义序列化以及反序列器
  • 6 Redis的慢查询配置原理
  • JAVA小游戏 “拼图”
  • Spring 配置
  • 全新酷盒9.0源码:多功能工具箱软件的最新iapp解决方案
  • aspose.cells java合并多个excel
  • 【每日一题】三个无重叠子数组的最大和
  • react之基于@reduxjs/toolkit使用react-redux
  • 基于51单片机水位监测控制报警仿真设计( proteus仿真+程序+设计报告+讲解视频)
  • git基本用法和操作
  • 设计模式-组合模式-笔记
  • Android 弹出自定义对话框
  • (论文阅读40-45)图像描述1
  • 4核8G服务器价格选择轻量还是CVM合适?
  • Selenium操作已经打开的Chrome浏览器窗口
  • 创新研报|新业务发展是CEO推动企业增长的必要选择 – Mckinsey研究
  • rv1126-rv1109-openssh
  • MySQL中json类型,你使用过吗
  • MATLAB 状态空间设计 —— LQG/LQR 和极点配置算法
  • 杭州-区块链前瞻性论坛邀请函​
  • ElasticSearch学习篇6_ES实践与Lucene对比及原理分析技术分享小记
  • mysql练习1
  • 【2017年数据结构真题】
  • 神辅助 Cursor 编辑器,加入 GPT-4 让编码更轻松!
  • 解决Qt5.13.0无MySQL驱动问题