0

0

C++怎么使用gRPC框架_C++分布式通信与gRPC应用指南

穿越時空

穿越時空

发布时间:2025-11-26 11:56:02

|

296人浏览过

|

来源于php中文网

原创

掌握gRPC在C++中的应用需先安装protoc和gRPC库,再定义.proto接口文件并生成C++代码,接着实现服务端和客户端逻辑,最后通过CMake正确编译链接依赖库,完成高效分布式通信。

c++怎么使用grpc框架_c++分布式通信与grpc应用指南

使用gRPC框架进行C++开发:分布式通信实战指南

在现代分布式系统中,服务之间的高效通信至关重要。gRPC 是 Google 开发的高性能、跨语言的远程过程调用(RPC)框架,基于 HTTP/2 协议和 Protocol Buffers(Protobuf),特别适合微服务架构下的 C++ 服务通信。本文将带你从零开始掌握如何在 C++ 中使用 gRPC。

1. 环境准备与依赖安装

要在 C++ 中使用 gRPC,需先安装必要的工具链:

  • Protocol Buffers 编译器(protoc):用于将 .proto 文件编译为 C++ 代码。
  • gRPC C++ 库:包含运行时支持和头文件。

推荐使用包管理器或源码编译方式安装。以 Ubuntu 为例:

立即学习C++免费学习笔记(深入)”;

sudo apt-get install -y build-essential autoconf libtool pkg-config
git clone -b v1.50.1 https://github.com/grpc/grpc
cd grpc
git submodule update --init
make -j$(nproc)
sudo make install

确保 protoc 版本兼容,必要时单独安装:

sudo apt-get install protobuf-compiler
protoc --version

2. 定义服务接口(.proto 文件)

gRPC 使用 Protobuf 定义服务接口和数据结构。创建一个 helloworld.proto 文件:

syntax = "proto3";

package helloworld;

service Greeter { rpc SayHello (HelloRequest) returns (HelloReply); }

message HelloRequest { string name = 1; }

message HelloReply { string message = 1; }

该定义声明了一个名为 Greeter 的服务,提供 SayHello 方法,接收请求并返回响应。

使用 protoc 生成 C++ 代码:

protoc -I=. --grpc_out=. --plugin=protoc-gen-grpc=`which grpc_cpp_plugin` helloworld.proto
protoc -I=. --cpp_out=. helloworld.proto

生成两个文件:helloworld.pb.cc(消息类)和 helloworld.grpc.pb.cc(服务和桩代码)。

ChatWP
ChatWP

一个AI聊天机器人,可以直接回答你的WordPress问题。

下载

3. 实现服务端逻辑

创建服务端实现,继承自生成的抽象服务类:

#include 
#include 
#include 
#include 
#include "helloworld.grpc.pb.h"

using grpc::Server; using grpc::ServerBuilder; using grpc::Status; using grpc::ServerContext; using helloworld::HelloRequest; using helloworld::HelloReply; using helloworld::Greeter;

class GreeterServiceImpl final : public Greeter::Service { Status SayHello(ServerContext context, const HelloRequest request, HelloReply* reply) override { std::string prefix("Hello "); reply->set_message(prefix + request->name()); return Status::OK; } };

void RunServer() { std::string server_address("0.0.0.0:50051"); GreeterServiceImpl service;

ServerBuilder builder; builder.AddListeningPort(server_address, grpc::InsecureServerCredentials()); builder.RegisterService(&service); std::unique_ptr server(builder.BuildAndStart()); std::cout << "Server listening on " << server_address << std::endl; server->Wait(); }

int main() { RunServer(); return 0; }

该服务监听 50051 端口,处理客户端的 SayHello 调用。

4. 实现客户端调用

客户端通过存根(stub)调用远程方法:

#include 
#include 
#include "helloworld.grpc.pb.h"

using grpc::Channel; using grpc::ClientContext; using grpc::Status; using helloworld::HelloRequest; using helloworld::HelloReply; using helloworld::Greeter;

class GreeterClient { public: GreeterClient(std::sharedptr channel) : stub(Greeter::NewStub(channel)) {}

std::string SayHello(const std::string& user) { HelloRequest request; request.set_name(user);

HelloReply reply;
ClientContext context;

Status status = stub_->SayHello(&context, request, &reply);
if (status.ok()) {
  return reply.message();
} else {
  std::cout << "RPC failed: " << status.error_code()
            << ": " << status.error_message() << std::endl;
  return "RPC failed";
}

}

private: std::uniqueptr<:stub> stub; };

int main() { GreeterClient client(grpc::CreateChannel( "localhost:50051", grpc::InsecureChannelCredentials())); std::string user("World"); std::string reply = client.SayHello(user); std::cout

客户端创建通道连接到服务端,构造存根并发起同步调用。

5. 编译与链接注意事项

C++ 项目需正确链接 gRPC 和 Protobuf 库。使用 CMake 示例:

cmake_minimum_required(VERSION 3.14)
project(helloworld)

find_package(Protobuf REQUIRED) find_package(gRPC CONFIG REQUIRED)

set(CMAKE_CXX_STANDARD 17)

add_executable(greeter_server server.cpp helloworld.pb.cc helloworld.grpc.pb.cc) add_executable(greeter_client client.cpp helloworld.pb.cc helloworld.grpc.pb.cc)

target_link_libraries(greeter_server ${_PROTOBUF_LIBPROTOBUF} gRPC::grpc++ gRPC::gpr )

target_link_libraries(greeter_client ${_PROTOBUF_LIBPROTOBUF} gRPC::grpc++ gRPC::gpr )

确保库路径和依赖正确配置,避免链接错误。

基本上就这些。掌握 gRPC 在 C++ 中的应用,能显著提升服务间通信效率和系统可维护性。关键是定义好接口、生成代码、实现服务逻辑,并正确编译链接。不复杂但容易忽略细节。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

225

2023.10.07

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

311

2023.08.02

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

311

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

513

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

46

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

183

2025.08.29

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

529

2023.12.01

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

25

2025.12.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.2万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号