c++的grpc例子

官方文档

grpc.io

安装cmake

  • Linux
sudo apt install -y cmake
  • mac
brew install cmake

终端输入以下命令查看版本:

cmake --version

cmake version 3.21.2

安装gRPC的其他工具

下面有gRPC的依赖工具:

  • Linux
sudo apt install -y build-essential autoconf libtool pkg-config
  • mac
brew install autoconf automake libtool pkg-config

克隆grpc及其子模块

git clone --recurse-submodules -b v1.40.0 https://github.com/grpc/grpc

构建和安装 gRPC 和协议缓冲区

以下命令构建并在本地安装 gRPC 和 Protocol Buffers:

$ cd grpc
$ mkdir -p cmake/build
$ pushd cmake/build
$ cmake -DgRPC_INSTALL=ON \
      -DgRPC_BUILD_TESTS=OFF \
      -DCMAKE_INSTALL_PREFIX=`/usr/local/gRPC` \
      ../..
$ make -j
$ make install
$ popd

这里需要将安装路径的bin目录放到系统环境内!!!

Mac

使用如下命令打开配置文件:

vim ~/.bash_profile

将下面复制进去,保存退出

export PATH=$PATH:/usr/local/gRPC/bin

Linux

使用如下命令打开配置文件:

vim ~/.bashrc

将下面复制进去,保存退出

export PATH=$PATH:/usr/local/gRPC/bin

构建示例

这部分代码包含在上面克隆的仓库内。
1、切换到示例目录:

cd examples/cpp/helloworld

2、使用cmake以下命令构建示例:

$ mkdir -p cmake/build
$ pushd cmake/build
$ cmake -DCMAKE_PREFIX_PATH=`/usr/local/gRPC` ../..
$ make -j

在这里make -j时遇见了一个错误:

/usr/local/gRPC/include/grpcpp/impl/codegen/sync.h:35:10: fatal error: 'absl/synchronization/mutex.h' file not found
#include "absl/synchronization/mutex.h"
         ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1 error generated.

这是因为在目录下缺失文件造成,用下面的命令进行copy

sudo cp -r ./grpc/third_party/abseil-cpp/absl /usr/local/gRPC/include

/usr/local/gRPC和上main保持一致,即安装gRPC的目录。
然后重新执行make -j4,成功后在build目录下已经生成可执行文件。

huzd@huzddeMacBook-Pro build % ls
CMakeCache.txt		greeter_async_client	greeter_callback_server	helloworld.grpc.pb.h
CMakeFiles		greeter_async_client2	greeter_client		helloworld.pb.cc
Makefile		greeter_async_server	greeter_server		helloworld.pb.h
cmake_install.cmake	greeter_callback_client	helloworld.grpc.pb.cc	libhw_grpc_proto.a

运行服务:

huzd@huzddeMacBook-Pro build % ./greeter_server 
Server listening on 0.0.0.0:50051

运行客户:

huzd@huzddeMacBook-Pro build % ./greeter_client
Greeter received: Hello world
huzd@huzddeMacBook-Pro build % ./greeter_client
Greeter received: Hello world
huzd@huzddeMacBook-Pro build % ./greeter_client
Greeter received: Hello world
huzd@huzddeMacBook-Pro build % 

已经实现功能的调用。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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的特性和优势,并在实际项目中应用它们。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值