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

grpc四种数据流

grpc四种数据流

简介

1.简单模式

这种模式最为传统,即客户端发起一次请求,服务端响应一个数据,这和大家平时熟悉的rpc没什么区别,所以不在详细介绍

2.服务端数据流模式

这种模式是客户端发起一次请求,服务端返回一段连续的数据流。典型的例子是客户端向服务端发送一个股票代码,服务端就把该股票的实时数据源源不断的返回给客户端。

3.客户端数据流模式

与服务端数据流模式相反,这次是客户端源源不断的向服务端发送数据流,而在发送结束后,由服务端返回一个响应。典型的例子是物联网向服务器报送数据。

4.双向数据流模式

顾名思义,这是客户端和服务端都可以向对方发送数据流,这个时候双方的数据可以同时互相发送,也就是可以实现实时交互。典型的例子是聊天机器人

proto文件代码编写

哪一方需要源源不断的返回数据,就在那一端的前面添加stream关键字,表示流

syntax = "proto3";option go_package="../../common/stream/proto/v1";
service Greeter {rpc GetStream(StreamReqData) returns (stream StreamResData); //服务端流模式rpc PutStream(stream StreamReqData) returns (StreamResData); //客户端流模式rpc AllStream(stream StreamReqData) returns (stream StreamResData); //双向流模式
}message StreamReqData {string data = 1;
}message StreamResData {string data = 1;
}

服务端代码

  • 除三种流模式实现代码外整体代码与之前的普通模式无异

  • 服务端数据流模式: grpc生成的函数原型为:

    •   func GetStream(req *proto.StreamReqData, res proto.Greeter_GetStreamServer) error
      
    • proto.Greeter_GetStreamServer:使用方式类似于socket网络编程

  • 客户端数据流模式: grpc生成的函数原型为:

    •   func PutStream(cliStr proto.Greeter_PutStreamServer) error
      
  • 双向数据流模式:grpc生成的函数原型为:

    •   func AllStream(allStr proto.Greeter_AllStreamServer) error
      
package mainimport ("OldPackageTest/stream_grpc_test/proto""fmt""google.golang.org/grpc""net""sync""time"
)const PORT = ":50052"type server struct {
}func (s *server) GetStream(req *proto.StreamReqData, res proto.Greeter_GetStreamServer) error {i := 0for {i++_ = res.Send(&proto.StreamResData{Data: fmt.Sprintf("%v", time.Now().Unix()),})time.Sleep(time.Second)if i > 10 {break}}return nil
}func (s *server) PutStream(cliStr proto.Greeter_PutStreamServer) error {for {if a, err := cliStr.Recv(); err != nil {fmt.Println(err)break} else {fmt.Println(a.Data)}}return nil
}func (s *server) AllStream(allStr proto.Greeter_AllStreamServer) error {wg := sync.WaitGroup{}wg.Add(2)//启动两个协程,一发一收go func() {defer wg.Done()for {data, _ := allStr.Recv()fmt.Println("收到客户端消息:" + data.Data)}}()go func() {defer wg.Done()for {_ = allStr.Send(&proto.StreamResData{Data: "我是服务器"})time.Sleep(time.Second)}}()wg.Wait()return nil
}func main() {lis, err := net.Listen("tcp", PORT)if err != nil {panic(err)}s := grpc.NewServer()proto.RegisterGreeterServer(s, &server{})err = s.Serve(lis)if err != nil {panic(err)}
}

客户端代码

客户端实现代码简单,大家自己阅读即可

package mainimport ("context""fmt""sync""time""google.golang.org/grpc""OldPackageTest/stream_grpc_test/proto"
)func main() {conn, err := grpc.Dial("localhost:50052", grpc.WithInsecure())if err != nil {panic(err)}defer conn.Close()//服务端流模式c := proto.NewGreeterClient(conn)res, _ := c.GetStream(context.Background(), &proto.StreamReqData{Data: "go"})for {a, err := res.Recv() //如果大家懂socket编程的话就明白 send recvif err != nil {fmt.Println(err)break}fmt.Println(a.Data)}//客户端流模式putS, _ := c.PutStream(context.Background())i := 0for {i++_ = putS.Send(&proto.StreamReqData{Data: fmt.Sprintf("grpc %d", i),})time.Sleep(time.Second)if i > 10 {break}}//双向流模式allStr, _ := c.AllStream(context.Background())wg := sync.WaitGroup{}wg.Add(2)go func() {defer wg.Done()for {data, _ := allStr.Recv()fmt.Println("收到客户端消息:" + data.Data)}}()go func() {defer wg.Done()for {_ = allStr.Send(&proto.StreamReqData{Data: "go"})time.Sleep(time.Second)}}()wg.Wait()
}

相关文章:

grpc四种数据流

grpc四种数据流 简介 1.简单模式 这种模式最为传统,即客户端发起一次请求,服务端响应一个数据,这和大家平时熟悉的rpc没什么区别,所以不在详细介绍 2.服务端数据流模式 这种模式是客户端发起一次请求,服务端返回一段连续的数据流。典型的例子是客户端向服务端发…...

SpringCloud-Alibaba-Nacos教程

SpringCloud-Alibaba-Nacos教程 下载地址 https://github.com/alibaba/nacos/releases/tag/2.2.3 直接进入bin包 运行cmd命令 startup.cmd -m standalone 运行成功后 进入nacos可视化页面 账号密码默认都是nacos http://localhost:8848/nacos 微服务入驻Nacos服务注册…...

bug_java

文章目录 1.创建Maven时: idea报错为:java:错误:不支持发行版本52. Springbot启动报错-类文件具有错误的版本 61.0, 应为 52.0 1.创建Maven时: idea报错为:java:错误:不支持发行版本…...

【目标检测】旋转目标检测DOTA格式转YOLO格式标注

准备DOTA格式数据集: dota_dataset -- images |----- train |----- val -- labels |----- train |----- train_original |----- val |----- val_original 修改class_mapping和图片格式: ultralytics/data/converter.py convert_dota_to_yolo_obb() 转换标…...

运动想象 (MI) 迁移学习系列 (3) : MSFT

运动想象迁移学习系列:MSFT 0. 引言1. 主要贡献2. 数据增强方法3. 基于度量的空间滤波转换器3.1 空间过滤3.2 脑电图ViT3.2.1 变压器编码器层3.2.2 基于度量的损失函数 4. 实验结果4.1 消融实验4.2 基线任务对比4.3 跨主体 5. 总结欢迎来稿 论文地址:https://www.s…...

NeRF模型NeRF模型

参考视频:https://www.youtube.com/watch?vHfJpQCBTqZs&ab_channelVision%26GraphicsSeminaratMIT NeRF模型的输入输出: 输入: (x, y, z): 一个三维空间坐标,代表场景中的一个位置点(θ, φ): 视线方向,θ表示与y轴的夹角,φ表示与x轴的夹角,用两个角度可以…...

python爬虫(4)

#前期先说明一下为啥爬虫需要学习数组的存储和处理,只是说在你后期接触到最简单的爬虫后有一个地方可以存放你的数据# 下面为大家带来一个我在做excel表整理时的代码以及上次代码的结果 上次代码的结果: 新的代码: import numpy as np im…...

递归神经网络 (RNN) 及其变体 LSTM (长短期记忆) 和 GRU (门控循环单元)

递归神经网络(RNN, Recurrent Neural Networks)是一类用于处理序列数据的神经网络,特别适合于时间序列数据、语音、文本等连续数据的处理。RNN之所以独特,是因为它们在模型内部维持一个隐藏状态,该状态理论上可以捕获到…...

Redis的HyperLogLog原理介绍

Redis 的 HyperLogLog 数据结构实现了一种基于概率的基数估算算法,用于在占用极小内存的情况下估算一个集合中不重复元素(唯一值)的数量。以下是 HyperLogLog 算法的基本原理: 哈希函数: HyperLogLog 使用一个强散列函…...

微信小程序开发系列(二十六)·小程序运行机制(启动、前后台状态、挂起、销毁)和小程序更新机制

目录 1. 小程序运行机制 1.1 启动 1.2 前台和后台状态 1.3 挂起 1.4 销毁 2. 小程序更新机制 1. 小程序运行机制 1.1 启动 小程序启动可以分为两种情况,一种是冷启动,一种是热启动。 冷启动:如果用户首次打开,或小…...

百度信息流

计划: 流量选择 - 四个维度: 百度信息流 ; 整合了百度APP、WAP、PC各频道信息流和内容详情页的流量资源,广告和信息流内容资讯穿插展现;适合所有产品呢 好看视频; 汇集海量优质的视频内容,通过智能推荐算法为用户推送最适合的视频广告,视频广告在列表页有声…...

JAVA后端开发面试基础知识(十)——设计模式

创建型模式 创建型模式的作用就是创建对象,说到创建一个对象,最熟悉的就是 new 一个对象,然后 set 相关属性。但是,在很多场景下,我们需要给客户端提供更加友好的创建对象的方式,尤其是那种我们定义了类&am…...

红帽认证知识储备-Linux安全

Linux安全 内置安全机制 常见的系统用的centos中用的是SELinux,ubuntu用的是AppArmor,deepin什么都没用 SELINUX 定义 SELinux 是一个 Linux 内核安全模块,它增强了系统的安全性,通过实施强制访问控制策略来限制程序和用户对系…...

Rust 语言中的 dyn 关键字

在 Rust 中,&dyn Error 是一个指向动态类型的 Error trait 对象的引用。这里的 dyn 关键字用于表示一个动态分派的 trait 对象。动态分派允许你在运行时确定实际的对象类型,而不是在编译时。 dyn 关键字在 Rust 中用于替换早期版本中的 & 符号&…...

软件测试实战,Web项目网页bug定位详细分析总结(详全)

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 1、前置条件 1&a…...

清除Mac OS上Xcode占用的空间

最近自己的Mac OS存储空间严重不足,想了一下,大概是从安装 Xcode 之后出现,在系统下通过 du 命令分析各目录大小,发现大概下面几个目录占用空间比较大,所以针对这几个名目录作了一下清理,释放了几十个G的空…...

开源的Java图片处理库介绍

在 Java 生态系统中,有几个流行的开源库可以用于图片处理。这些库提供了丰富的功能,如图像缩放、裁剪、颜色调整、格式转换等。以下是几个常用的 Java 图片处理库的介绍,包括它们的核心类、主要作用和应用场景,以及一些简单的例子…...

论文笔记 Where Would I Go Next? Large Language Models as Human Mobility Predictor

arxiv 2023 08的论文 1 intro 1.1 人类流动性的独特性 人类流动性的独特特性在于其固有的规律性、随机性以及复杂的时空依赖性 ——>准确预测人们的行踪变得困难近期的研究利用深度学习模型的时空建模能力实现了更好的预测性能 但准确性仍然不足,且产生的结果…...

农场管理小程序|基于微信小程序的农场管理系统设计与实现(源码+数据库+文档)

农场管理小程序目录 目录 基于微信小程序的农场管理系统设计与实现 一、前言 二、系统设计 三、系统功能设计 1、用户信息管理 2、农场信息管理 3、公告信息管理 4、论坛信息管理 四、数据库设计 五、核心代码 七、最新计算机毕设选题推荐 八、源码获取&#x…...

【前端】vscode快捷键和实用Api整理

vscode的快捷键 创建a.html 生成模板 !回车 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" …...

烽火HG5143D光猫折腾实录:用Fiddler抓包+U盘拷贝,一步步拿到超级密码

烽火HG5143D光猫深度探索&#xff1a;从抓包分析到权限获取实战指南 家里新装的烽火HG5143D光猫限制太多&#xff1f;想实现桥接模式却找不到入口&#xff1f;作为一名长期折腾家庭网络的技术爱好者&#xff0c;我最近就遇到了这个棘手问题。电信提供的这款光猫默认屏蔽了许多高…...

不止于数据上传:基于阿里云和EC600S 4G模块,给你的STM32项目加上远程短信/电话告警功能

从数据上传到主动告警&#xff1a;基于STM32与EC600S的智能远程监控系统进阶设计 在物联网项目开发中&#xff0c;数据上传功能已成为基础配置&#xff0c;但真正的商业价值往往体现在异常事件的即时响应能力上。想象一下&#xff1a;当工业设备温度超标时&#xff0c;系统不仅…...

拆开看个究竟:暴力拆解微波炉整流管CL01-12,揭秘13层硅片堆叠的耐压秘密

暴力拆解微波炉整流管CL01-12&#xff1a;13层硅片堆叠背后的高压奥秘 微波炉高压整流二极管CL01-12看似普通&#xff0c;却藏着令人惊叹的工程智慧。当第一次用万用表测量时&#xff0c;发现它需要9V以上电压才能导通&#xff0c;这与普通二极管的0.7V形成鲜明对比。这种异常现…...

从‘一个向量’到‘三个向量’:为什么Transformer的Attention非得用Q、K、V?聊聊设计背后的权衡

从‘一个向量’到‘三个向量’&#xff1a;Transformer注意力机制中Q、K、V的设计哲学 在深度学习领域&#xff0c;Transformer架构彻底改变了自然语言处理的游戏规则。而其中最具革命性的设计&#xff0c;莫过于那个看似简单却暗藏玄机的注意力机制——特别是它独特的Q&#x…...

别再只用数组了!SV队列的insert/push/pop操作,5分钟上手实战

别再只用数组了&#xff01;SV队列的insert/push/pop操作&#xff0c;5分钟上手实战 在验证工程师的日常工作中&#xff0c;数组无疑是最常用的数据结构之一。但当你需要处理动态变化的激励数据或灵活管理的配置列表时&#xff0c;数组的固定大小特性往往会成为绊脚石。这时候&…...

Python调用VLC失败?别急,先检查你的VLC Media Player

1. 为什么Python调用VLC会失败&#xff1f; 很多Python开发者第一次使用python-vlc库时都会遇到一个经典错误&#xff1a;明明已经用pip安装了python-vlc&#xff0c;但在导入时却提示"找不到指定模块"。这个问题困扰过不少新手&#xff0c;包括我自己。记得第一次遇…...

SQLite4Unity3d终极教程:在Unity中快速集成SQLite数据库的完整指南

SQLite4Unity3d终极教程&#xff1a;在Unity中快速集成SQLite数据库的完整指南 【免费下载链接】SQLite4Unity3d SQLite made easy for Unity3d 项目地址: https://gitcode.com/gh_mirrors/sq/SQLite4Unity3d SQLite4Unity3d是专为Unity开发者设计的强大数据库集成解决方…...

如何破解音频格式限制:3步解锁QQ音乐加密文件的完整指南

如何破解音频格式限制&#xff1a;3步解锁QQ音乐加密文件的完整指南 【免费下载链接】qmc-decoder Fastest & best convert qmc 2 mp3 | flac tools 项目地址: https://gitcode.com/gh_mirrors/qm/qmc-decoder 你是否曾经下载了一首喜欢的歌曲&#xff0c;却只能在特…...

别再为MAC地址发愁了!三种为W5500/W5100等网络芯片生成合法地址的实战方法

WIZnet网络芯片MAC地址生成实战指南&#xff1a;从合规到高效 在嵌入式网络设备开发中&#xff0c;MAC地址就像设备的身份证号码&#xff0c;不仅需要全球唯一&#xff0c;还要符合行业规范。对于使用W5500、W5100等WIZnet系列网络芯片的开发者来说&#xff0c;如何生成既合法又…...

rtrvr.ai AI 子程序:零 token 成本自动化脚本,解决网络智能体认证难题!

rtrvr.ai 产品介绍rtrvr.ai 提供多种产品服务&#xff0c;包括博客、预约演示、定价、API 文档、扩展程序、云端服务等。AI 子程序功能特点只需录制一次浏览器任务&#xff0c;就能将其作为可调用工具进行回放&#xff0c;零 token 成本&#xff0c;100% 确定性&#xff0c;认证…...