如何在Golang中实现gRPC双向流

在Golang中实现gRPC双向流需先在.proto文件定义stream类型的rpc方法,如Chat(stream ChatMessage) returns (stream ChatMessage);接着使用protoc生成Go代码,得到服务端ChatService_ChatServer和客户端ChatService_ChatClient接口;服务端通过Recv()接收并用Send()发送消息,循环处理实现全双工通信;客户端则通过goroutine并发调用Send()和Recv(),实现双向数据传输。

如何在golang中实现grpc双向流

在Golang中实现gRPC双向流,核心是定义一个服务方法,其请求和响应都带有stream关键字,然后在客户端和服务端同时读写数据流。整个过程基于Protocol Buffers定义接口,并使用gRPC运行时处理通信。

定义.proto文件中的双向流方法

要在gRPC中启用双向流,首先需要在.proto文件中定义一个使用stream的rpc方法。这个方法的请求和响应类型都会携带stream标识。

syntax = "proto3";package example;message ChatMessage {    string user = 1;    string message = 2;}service ChatService {    rpc Chat(stream ChatMessage) returns (stream ChatMessage);}

上述定义表示Chat方法允许客户端和服务端持续发送消息,实现全双工通信。

生成Go代码

使用protoc配合gRPC插件生成Go代码:

立即学习“go语言免费学习笔记(深入)”;

protoc -I . --go_out=plugins=grpc:. chat.proto

会生成chat.pb.go文件,其中包含服务接口和客户端存根,重点关注生成的ChatService_ChatServerChatService_ChatClient类型。

实现服务端逻辑

服务端需循环读取客户端消息,同时可随时向客户端发送响应。

绘蛙AI修图 绘蛙AI修图

绘蛙平台AI修图工具,支持手脚修复、商品重绘、AI扩图、AI换色

绘蛙AI修图 285 查看详情 绘蛙AI修图

示例实现:

type ChatServer struct{}func (s *ChatServer) Chat(stream pb.ChatService_ChatServer) error {    for {        msg, err := stream.Recv()        if err != nil {            return err        }        // 处理收到的消息        response := &pb.ChatMessage{            user:    "server",            message: "echo: " + msg.message,        }        // 发送响应        if err := stream.Send(response); err != nil {            return err        }    }}

服务端通过Recv()接收流消息,Send()发送消息,直到连接关闭或发生错误。

实现客户端逻辑

客户端同样可以并发地发送和接收消息。

示例代码:

conn, _ := grpc.Dial("localhost:50051", grpc.WithInsecure())client := pb.NewChatServiceClient(conn)stream, _ := client.Chat(context.Background())// 启动goroutine接收服务端消息go func() {    for {        msg, err := stream.Recv()        if err != nil {            log.Println(err)            return        }        log.Printf("[%s] %s", msg.user, msg.message)    }}()// 发送消息for i := 0; i < 5; i++ {    msg := &pb.ChatMessage{        user:    "client",        message: fmt.Sprintf("hello %d", i),    }    stream.Send(msg)    time.Sleep(time.Second)}stream.CloseSend()

客户端使用Send()发送,Recv()接收,通常用单独的goroutine处理接收逻辑以避免阻塞。

基本上就这些。只要.proto定义正确,生成代码后按流式接口编写收发逻辑,就能实现稳定的双向通信。注意控制上下文超时、错误处理和资源释放,避免连接泄漏。

以上就是如何在Golang中实现gRPC双向流的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1076546.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 07:39:00
下一篇 2025年12月2日 07:39:21

相关推荐

  • PHP如何调用Go语言程序 调用Go程序的3种交互方式

    php调用go程序有三种方式:命令行调用、http服务和使用扩展。1. 命令行调用是通过exec等函数执行go可执行文件,优点是实现简单,适合非频繁调用;缺点是每次调用都要启动新进程,效率低。2. http服务是让go作为服务器接收php的http请求,优点是并发性能好,数据交换方便;缺点是需编写g…

    2025年12月10日 好文分享
    000
  • Python协程锁是如何实现的?它与其他语言的协程锁实现有何区别?

    深入探究Python协程锁的运行原理 本文将深入剖析Python协程锁的底层实现,并与其他编程语言(如Java、Golang)的协程锁机制进行对比分析,重点关注asyncio库中的锁机制,并扩展到更广泛的协程锁实现原理。 Python的asyncio库提供了一套协程同步原语,包括Lock、Event…

    2025年12月10日
    000
  • Laravel项目如何快速集成微信支付和支付宝支付?

    laravel 框架整合微信支付和支付宝支付 使用 laravel 框架开发时,整合微信支付和支付宝支付十分必要。下面将介绍如何使用现有的 easywechat 库实现这一功能。 easywechat 介绍 easywechat 是一个 golang 编写的微信 sdk,它为 php 框架提供了官方…

    2025年12月9日
    000
  • 如何将 PHP/Python 中对字典进行排序并生成签名的代码转换成 Golang?

    php / python 代码转 golang 问题: 如何将 php/python 中对字典进行排序并生成签名的代码转换成 golang? 解答: golang 代码: 立即学习“PHP免费学习笔记(深入)”; package mainimport ( “crypto/md5” “encoding…

    2025年12月9日
    000
  • Golang 如何实现 PHP 中的字典排序、序列化和签名生成?

    php/python 代码在 golang 中的转换 在 php 中,对字典进行排序并对其进行序列化以生成签名,这是常见的做法。在 golang 中,这一过程可以进行类似的实现。 首先,对字典的键进行排序。 package mainimport ( “fmt” “sort”)func main() …

    2025年12月9日
    000
  • 为什么 PHP 源码讲解资源比 Go 少?

    PHP 与 Go 源码讲解差异 在编程领域,Golang 的源码讲解资源丰富,然而 PHP 相关的则相对稀少。这是为什么呢? Go 的设计目标 与 PHP 等脚本语言不同,Go 的设计目标是媲美 C/C++ 等编译型语言。这导致 Go 的底层封装更薄,为优化和调优提供了更大空间。此外,Go 的 FA…

    2025年12月9日
    000
  • Golang 中 var 和 type 定义结构有什么区别?

    golang 中 var 和 type 定义结构的区别 在 golang 中,使用 var 和 type 定义结构时,两者之间存在一些关键差异。 当使用 var 定义结构时,本质上是在创建该结构类型的匿名实例。这意味着该结构没有明确的名称,只能通过变量名来访问它的字段。 示例: 立即学习“go语言免…

    2025年12月9日
    000
  • Go 结构体定义:var 和 type 的区别是什么?

    golang var 和 type 应用于结构的区别 对于 go 编程语言的新手,可能会注意到不同的结构定义方式,即使用 var 和 type 关键字。本文将详细说明这两种写法的区别。 匿名结构 当使用 var 关键字声明结构时,实际上是在创建一个 匿名结构。匿名结构没有显式声明其类型,而是使用大括…

    2025年12月9日
    000
  • Go 中 var 和 type 声明结构体有什么区别?

    golang 中 var 和 type 声明结构的区别 对于 go 新手来说,区分 var 和 type 声明结构的区别可能令人困惑。以下详细介绍它们的异同: 1. 相同点 这两种语法都可以用于定义一个结构体,并且都可以在包含匿名字段的情况下使用。匿名字段是指没有显式名称的字段,其类型从上下文中推断…

    2025年12月9日
    000
  • 如何将 Go 函数扩展到 PHP 中?

    通过安装 cgo、创建 go 包、编写 go 函数、生成 c 头文件、创建 php 扩展并编译和安装它,可以将 go 函数扩展到 php 中。这样,php 代码就可以直接调用扩展后的 go 函数,从而结合两种语言的优势。 如何将 Go 函数扩展到 PHP 中 Go 是一种跨平台编译语言,以其高性能和…

    2025年12月9日
    000
  • PHP 函数如何与 Go 交互:提升跨语言性能

    php 函数可通过 syscall.syscall 函数与 go 交互,提升跨语言性能。步骤如下:在 php 中创建函数 callgofunction,接受函数名称和参数数组。在 go 中声明要导出的函数,例如 gofunction(a, b uint64) uint64。编译 go 代码并加载 s…

    2025年12月9日
    000
  • 如果 PHP 失宠,我会选择哪种后端语言?

    作为一名经验丰富的后端开发人员,php 在我的职业生涯中发挥了重要作用。然而,科技格局瞬息万变,我们必须时刻做好迎接新挑战的准备。那么,如果今天 php 突然消失了,我会选择哪种后端语言来取代它呢?这是我的坦率见解。 1. Golang首先,我毫无疑问会选择Golang(Go语言)。为什么?因为Go…

    2025年12月9日 好文分享
    100
  • PHP 函数如何与 Go 交互?

    PHP 函数如何与 Go 交互 PHP 和 Go 是两种截然不同的编程语言,具有不同的语法和特性。然而,在某些情况下,您可能需要在 PHP 应用程序和 Go 服务之间进行交互。 方法 1:使用 HTTP 请求 您可以使用标准 HTTP 请求在 PHP 和 Go 之间发送数据。 立即学习“PHP免费学…

    2025年12月9日
    000
  • PHP 函数如何与 Go 交互

    php 和 go 可通过结合使用实现优势互补,php 擅长处理 http 请求和数据库交互,而 go 具有高性能和并发性。通过 go 创建服务,并通过 php 发出请求,可以实现语言间的交互。实战中,php 应用程序可通过 curl 请求访问由 go 编写并部署的 api,扩展应用程序功能。 使用 …

    2025年12月9日
    000
  • CSV 文件处理基准测试:Golang、NestJS、PHP、Python

    介绍 高效处理大型 csv 文件是许多应用程序中的常见要求,从数据分析到 etl(提取、转换、加载)过程。在本文中,我想对四种流行编程语言(golang、带有 nestjs 的 nodejs、php 和 python)在 macbook pro m1 上处理大型 csv 文件的性能进行基准测试。我的…

    2025年12月9日 好文分享
    000
  • 币安交易所全球官网入口 Binance官方认证APP下载地址

    币安 binance 是全球领先的数字资产交易平台,支持现货交易、期货合约、理财产品等多样化服务。本文将为你介绍 币安全球官网入口 及其 官方 app 下载方式,帮助你安全访问并安装。 币安全球官网入口 建议通过官方域名访问币安官网:— 在这里你可以完成注册、登录、资产管理、充值提现等操作。 币安官…

    2025年12月9日
    000
  • Solana(SOL)币是什么?SOL工作原理、代币经济学及购买方法

    solana(sol)是一种高性能的区块链平台,旨在为去中心化应用(dapps)和加密项目提供可扩展、快速且低成本的基础设施。它由anatoly yakovenko于2017年创立,并于2020年正式推出主网。solana最显著的特点是其创新的共识机制,特别是历史证明(proof of histor…

    2025年12月9日
    000
  • Cardano怎么进行ADA跨平台交易?在不同平台间交易Cardano的技巧

    选择支持ADA的主流平台如币安或Coinbase进行交易,确保流动性与合规性;通过去中心化交易所如SUNSwap连接Yoroi等账户实现跨链兑换,注意核对合约地址;利用经审计的跨链桥如Milkomeda或Wormhole将ADA转移至以太坊等目标链,完成网络间资产映射。 一、选择支持ADA的主流交易…

    2025年12月9日
    000
  • BNX币是什么?购买指南及风险提示

    BNX是BinaryX生态系统的治理代币,用于GameFi、IGO平台及社区治理。获取需通过DEX如PancakeSwap,用BNB或BUSD兑换,操作时需核对合约地址并注意滑点与手续费。投资面临市场波动、项目发展、智能合约安全及流动性风险,需谨慎评估。 欧易okx官网入口: 欧易okxAPP下载链…

    2025年12月9日
    000
  • 什么是 Saga (SAGA) 币?SAGA代币经济学、价格预测及购买方法

    saga (saga) 是加密货币交易所币安的第 51 个 launchpool 项目。该项目是一个专为开发者打造的 layer 1 协议,旨在帮助他们使用“链式组件”(chainlets)构建无限可扩展的应用进程。自成立以来,saga 发展迅猛,两年内已有 350 个项目基于其协议构建,其中 80…

    2025年12月9日 好文分享
    000

发表回复

登录后才能评论
关注微信