首页 > 后端开发 > C++ > 正文

c++怎么使用gRPC进行远程过程调用_c++ gRPC远程过程调用方法

下次还敢
发布: 2025-10-06 12:51:02
原创
947人浏览过
首先安装gRPC环境并定义.proto接口文件,接着生成C++代码,然后分别实现服务端和客户端逻辑,最后编译链接并运行程序完成RPC通信。

c++怎么使用grpc进行远程过程调用_c++ grpc远程过程调用方法

在C++中使用gRPC进行远程过程调用(RPC),需要经过几个关键步骤:定义服务接口、生成代码、实现服务端和客户端逻辑,并运行通信。下面详细介绍如何操作。

1. 安装gRPC环境

要使用gRPC,先确保系统中安装了gRPC开发库。可以通过源码编译或包管理器安装。

Ubuntu/Debian 示例:

安装依赖:

  • sudo apt-get update
  • sudo apt-get install build-essential autoconf libtool pkg-config
  • git clone -b v1.50.1 https://github.com/grpc/grpc.git
  • cd grpc && git submodule update --init
  • mkdir -p cmake/build && cd cmake/build
  • cmake ../..
  • make -j4
  • sudo make install

这会安装gRPC核心库和Protocol Buffers编译器(protoc)。

立即进入豆包AI人工智官网入口”;

立即学习豆包AI人工智能在线问答入口”;

2. 定义 .proto 文件

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

syntax = "proto3";
<p>package example;</p><p>// 定义请求消息
message HelloRequest {
string name = 1;
}</p><p>// 定义响应消息
message HelloReply {
string message = 1;
}</p><p>// 定义服务
service Greeter {
rpc SayHello (HelloRequest) returns (HelloReply);
}</p>
登录后复制

这个文件声明了一个名为 SayHello 的远程方法,接收一个字符串参数并返回一条消息。

3. 生成 gRPC 代码

使用 protoc 编译器生成 C++ 代码:

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

执行后会生成四个文件:

豆包AI编程
豆包AI编程

豆包推出的AI编程助手

豆包AI编程483
查看详情 豆包AI编程
  • helloworld.pb.h
  • helloworld.pb.cc
  • helloworld.grpc.pb.h
  • helloworld.grpc.pb.cc

这些是序列化消息和服务存根的基础。

4. 实现服务端

编写服务端代码,继承生成的服务类并重写方法:

#include <iostream>
#include <memory>
#include <string>
#include <grpcpp/grpcpp.h>
#include "helloworld.grpc.pb.h"
<p>using grpc::Server;
using grpc::ServerBuilder;
using grpc::Status;
using grpc::StatusCode;
using example::HelloRequest;
using example::HelloReply;
using example::Greeter;</p><p>class GreeterServiceImpl final : public Greeter::Service {
Status SayHello(ServerContext<em> context, const HelloRequest</em> request,
HelloReply* reply) override {
std::string prefix("Hello, ");
reply->set_message(prefix + request->name());
return Status::OK;
}
};</p><p>void RunServer() {
std::string server_address("0.0.0.0:50051");
GreeterServiceImpl service;</p><p>ServerBuilder builder;
builder.AddListeningPort(server_address, grpc::InsecureServerCredentials());
builder.RegisterService(&service);
std::unique_ptr<Server> server(builder.BuildAndStart());
std::cout << "Server listening on " << server_address << std::endl;
server->Wait();
}</p><p>int main() {
RunServer();
return 0;
}</p>
登录后复制

5. 实现客户端

客户端创建存根并调用远程方法:

#include <iostream>
#include <grpcpp/grpcpp.h>
#include "helloworld.grpc.pb.h"
<p>using grpc::Channel;
using grpc::ClientContext;
using grpc::Status;
using example::HelloRequest;
using example::HelloReply;
using example::Greeter;</p><p>class GreeterClient {
public:
GreeterClient(std::shared<em>ptr<Channel> channel)
: stub</em>(Greeter::NewStub(channel)) {}</p><p>std::string SayHello(const std::string& user) {
HelloRequest request;
request.set_name(user);</p><pre class='brush:php;toolbar:false;'>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<Greeter::Stub> stub; };

int main(int argc, char** argv) { GreeterClient client(grpc::CreateChannel( "localhost:50051", grpc::InsecureChannelCredentials())); std::string user("world"); std::string reply = client.SayHello(user); std::cout << "Response: " << reply << std::endl; return 0; }

6. 编译与运行

编译时需链接 gRPC 和 Protobuf 库。示例 Makefile 片段:

CXX = g++
CXXFLAGS = -std=c++11
PROTOBUF_LIB = -lprotobuf
GRPC_LIB = -lgrpc++ -lgrpc
LIBS = $(PROTOBUF_LIB) $(GRPC_LIB)
<p>all: greeter_client greeter_server</p><p>greeter_client: helloworld.pb.o helloworld.grpc.pb.o client.o
$(CXX) $^ -o $@ $(LIBS)</p><p>greeter_server: helloworld.pb.o helloworld.grpc.pb.o server.o
$(CXX) $^ -o $@ $(LIBS)</p><p>clean:
rm -f *.o greeter_client greeter_server</p>
登录后复制

运行流程:

  • 先启动服务端:./greeter_server
  • 再运行客户端:./greeter_client
  • 客户端将输出:Response: Hello, world

基本上就这些。按照这个流程,你可以在C++项目中成功集成gRPC实现远程调用。关键是理解.proto定义、代码生成机制和服务/客户端的交互模式。

以上就是c++++怎么使用gRPC进行远程过程调用_c++ gRPC远程过程调用方法的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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