gRPC C++ 异步双向流例子 -支持多线程与连续发送消息

grpc_async_bidirectional_stream_example

github 地址:https://github.com/fananchong/grpc_async_bidirectional_stream_example

例子基于线上稳定、高效跑了 1 年以上的 gRPC C++ 库网络框架

最开始作为测试,实验性放到 github 抓虫

使用的是异步双向流

简化编码,在异步双向流基础上,引入 echo 型编码设计模式

类似如下:

  1. 实现对应类方法:
    bool Msg_TestService_Stream::OnProcess()
    {
        INFO("Msg_TestService_Stream::OnProcess");
        switch (request_.Msg_case())
        {
        case test::Frame::kEcho:
        {
            auto v = reply_.mutable_echo();
            v->set_data(request_.echo().data());
            // CloseStream();
        }
        break;
        case test::Frame::kPing:
            break;
        default:
            break;
        }
        return true;
    }
    
  2. 注册服务
    gserver.RegisterMsg(new Msg_TestService_Stream(service));
    

连续发送消息

最近更新,上了流消息处理里,可以连续发送 N 个消息

类似如下用法:

bool Msg_TestService_Stream2::OnProcess()
{
    INFO("Msg_TestService_Stream2::OnProcess");
    switch (request_.Msg_case())
    {
    case test::Frame::kEcho:
    {
        test::Frame rep1;
        auto v1 = rep1.mutable_echo();
        v1->set_data(fmt::format("{} #1", request_.echo().data()));
        SendMsg(rep1, false);

        test::Frame rep2;
        auto v2 = rep2.mutable_echo();
        v2->set_data(fmt::format("{} #2", request_.echo().data()));
        SendMsg(rep2, false);

        test::Frame rep3;
        auto v3 = rep3.mutable_echo();
        v3->set_data(fmt::format("{} #3", request_.echo().data()));
        SendMsg(rep3, true);
        return false;
    }
    break;
    case test::Frame::kPing:
        break;
    default:
        break;
    }
    return true;
}

例子支持的功能

目前支持以下功能:

  • 异步一元函数处理
  • 异步双向流处理
  • 支持多线程
  • 支持同个流处理内,发送 N 次消息
  • 流定时回调处理

其他

基本上,以上功能,绝大多数需求都能满足了。欢迎 star ,讨论

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 18
    评论
### 回答1: gRPC C是一个用C语言实现的开源高性能远程过程调用(RPC)框架。它基于Google的Protocol Buffers(protobuf)和HTTP/2协议,可以用于构建分布式系统中的服务器和客户端。下面以300字中文回答gRPC C的例子和优势: gRPC C的例子包括服务器和客户端的实现。在服务器方面,我们可以使用gRPC C来编写一个简单的服务器应用程序,它提供一些远程方法供客户端调用。我们可以定义一组方法和消息类型,在gRPC C中使用protobuf来序列化和反序列化这些消息,然后基于这些方法编写服务器端逻辑。客户端可以使用gRPC C的API来调用服务器上的方法,并获得返回结果。 gRPC C的优势主要体现在以下几个方面: 1. 高性能:gRPC C基于HTTP/2协议,通过多路复用和水线技术实现了高效的并发通信。这使得gRPC C在网络传输效率和性能方面表现出色,能够处理大量请求和响应。 2. 跨平台支持gRPC C可以在各种操作系统上运行,包括Linux、Windows和MacOS等。这使得开发者可以在不同的平台上使用相同的代码和API来构建分布式系统。 3. 强大的工具支持gRPC C提供了丰富的工具来帮助开发者构建和测试gRPC应用。例如,它提供了自动生成代码的工具,可以根据protobuf文件自动创建服务器和客户端的代码。此外,gRPC C还提供了CLI工具,用于测试和调试gRPC应用。 4. 扩展性和可靠性:gRPC C支持多种负载均衡模式和错误处理机制,可以根据具体的需求进行配置。这使得gRPC C在构建大规模分布式系统时具有良好的可扩展性和可靠性。 总之,gRPC C是一个功能强大且性能优越的远程过程调用框架,可以帮助开发者快速构建高效的分布式系统。它提供了丰富的工具和跨平台支持,使得开发和部署变得更加简单和可靠。 ### 回答2: gRPC C是一个用于构建高性能、跨平台的分布式系统的开源框架。它基于Google开发gRPC协议,使用了Protocol Buffers作为默认的序列化机制。gRPC C提供了一系列功能强大的API,可以让开发者轻松地构建可扩展的分布式应用程序。 在gRPC C中,我们可以使用例子来更好地理解和学习框架的使用方式。gRPC C提供了一些示例代码,可作为开发者的起点和参考。这些示例覆盖了不同功能和用例,帮助开发者快速上手和理解具体的用法。 这些例子包括但不限于以下几个方面: 1. HelloWorld:这是最简单的示例,展示了如何使用gRPC C来实现一个基本的客户端-服务器通信。它涉及到建立服务器和客户端的连接,发送和接收简单的消息。 2. RouteGuide:这个示例演示了如何使用gRPC C构建一个简单的位置服务应用程序。它通过gRPC C的API实现了一些常见操作,如新建、添加、查询位置等。 3. Chat:这个示例展示了如何利用gRPC C实现一个简单的聊天应用程序。它使用gRPC C的式处理能力,支持多个客户端同时与服务器进行通信,实现实时消息的广播和接收。 通过运行和分析这些示例,开发者可以学习到gRPC C的各种功能和用法。这些示例提供了一个实践的方式,让开发者能够更好地理解和掌握gRPC C框架。开发者可以根据自身需求和具体场景,参考这些示例并进行相应的修改和定制。 ### 回答3: gRPC C是一个基于C语言的远程过程调用(RPC)框架,它可以让不同的应用程序在网络上相互通信。提供了跨越不同语言和平台的高效通信机制。 gRPC C的例子主要是用来演示如何在C语言中使用gRPC进行远程过程调用。这些例子通常包括一个服务器端和一个或多个客户端。通过这些例子,我们可以了解gRPC的基本概念和使用方法。 在gRPC C的例子中,通常会涉及到定义服务的接口文件、使用协议缓冲区(Protocol Buffers)来定义消息的结构和传输格式,以及实现服务器端和客户端的具体逻辑。通过这些例子,我们可以学习如何在C语言中使用gRPC构建分布式系统。 这些例子可以帮助我们理解gRPC的工作原理,并实现简单的分布式应用程序。通过这些例子,我们可以学习到如何定义服务接口、处理请求和响应、处理错误和异常等。 总而言之,gRPC C的例子是帮助我们在C语言中学习和使用gRPC的有效工具。它们提供了一个实用的指南,让我们能够快速入门并开始构建分布式应用程序。通过这些例子,我们可以更深入地了解gRPC的特性和优势,并在实际项目中应用它们。
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fananchong2

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值