gRPC 四模式之 双向流RPC模式

news/2024/12/21 20:25:51/

双向流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.ppmy.cn/news/1226577.html

相关文章

C语言循环结构 while循环

while循环 while循环语句概述while循环输出20个数while循环注意事项 while循环语句概述 作用&#xff1a;满足循环条件&#xff0c;执行循环语句 语法&#xff1a;while(循环条件){ 循环语句 } 解释&#xff1a;只要循环条件的结果为真&#xff0c;就执行循环语句 while循环输…

【Linux】进程间通信 -- 共享内存

共享内存 共享内存是SystemV标准进程间通信的一种&#xff0c;该标准还有消息队列和信号量&#xff0c;但下文主要介绍共享内存&#xff0c;然后在谈一下信号量的内容。SystemV标准的进程间通信可以看做单机版的进程间通信。 // 1. log.hpp #pragma once#include <iostrea…

ClickHouse建表优化

1. 数据类型 1.1 时间字段的类型 建表时能用数值型或日期时间型表示的字段就不要用字符串&#xff0c;全String类型在以Hive为中心的数仓建设中常见&#xff0c;但ClickHouse环境不应受此影响。 虽然ClickHouse底层将DateTime存储为时间戳Long类型&#xff0c;但不建议存储Long…

代码随想录 Day47 动态规划15 LeetCode T583 两个字符串的删除操作 T72 编辑距离

LeetCode T583 两个字符串的删除操作 题目链接:583. 两个字符串的删除操作 - 力扣&#xff08;LeetCode&#xff09; 题目思路: 本题有两个思路 1.使用两个字符串的长度之和-2*最长公共子串(换汤不换药) 代码随想录Day45 动态规划13 LeetCode T1143最长公共子序列 T1135 不相交…

freeCodeCamp响应式网页设计笔记

h1到h6标题元素&#xff0c;用于表明其内容的重要性&#xff0c;数字越低&#xff0c;重要性越高&#xff0c;所以h2元素内容的重要性应该低于h1元素&#xff0c;所以在编程中&#xff0c;每页应尽量只使用一个h1元素&#xff0c;并将重要性较低的标题放在重要性较高的标题之下…

在 Streamlit 中使用自定义 CSS 创建加密仪表板

一、说明 仪表板是表示任何类型数据的好方法,它是一种可以很好地理解我们正在处理的数据的形式。使用 HTML、CSS 和 JavaScript 框架构建令人惊叹的仪表板可能是一项非常棘手的工作,尤其是当您想要向仪表板添加复杂的功能和复杂的设计时。但不用担心,Python 会来拯救…

asp.net学生成绩评估系统VS开发sqlserver数据库web结构c#编程计算机网页项目

一、源码特点 asp.net 学生成绩评估系统 是一套完善的web设计管理系统&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。 系统运行视频连接&#xff1a;https://www.bilibili.com/video/BV1Wz4y1A7CG/ 二、功能介绍 本系统使用Microsof…

电压跟随器

电压跟随器即输入多大电压就输出多大的电压&#xff0c;那其起什么作用呢&#xff0c;直接用导线不行吗&#xff1f; 下图为Multisim软件仿真结果&#xff0c;很明显输入电压6.5V输出电压使用万用表测得同为6.5V&#xff0c;验证了电压跟随器的作用。 在同相放大电路的基础上&a…