这里我们运用vcpkg去下载安装gRPC,进入vcpkg目录后,执行命令:.\vcpkg.exe install grpc:x64-windows
grpc在vcpkg里面安装完成后,我们就来使用grpc做一个简单的例子。
gRPC顾名思义,就是google的RPC方案,基于protobuf数据传输,其中proto文件的定义约定了服务器端和客户端的服务接口协议。
这里我们就用加法和乘法作为服务器端提供的服务,让客户端去调用(RPC),我们建立三个文件夹CPP_Server, CPP_Client, proto 来分别存储服务器端代码,客户端代码,以及proto文件。项目配置选用cmakelist.txt和cmake来管理。
1. 服务器端和客户端的proto定义(calculation.proto文件):
syntax = "proto3";
package data_handler;service CalculationInterface{
// Add operation
rpc Add(AddRequest) returns (AddReply){}
// Multiply operation
rpc Multiply(MultiplyRequest) returns (MultiplyReply){}
}message AddReply{
int32 result = 1;
}message AddRequest{
int32 param1 = 1;
int32 param2 = 2;
}message MultiplyReply{
int32 result = 1;
}message MultiplyRequest{
int32 param1 = 1;
int32 param2 = 2;
}
2. 服务器端代码
在服务器端,我们要在cmakelist里面进行proto文件的解析执行成相应的.pb.cc,.pb.h,.grpc.pb.cc,.grpc.pb.h文件,同时对项目文件的配置。
那么我们必然要先找到grpc, protobuf库和执行文件。这时候就需要用到vcpkg这套包管理器,
而下面这句话就是让vcpkg的包管理起作用的关键:
set(CMAKE_TOOLCHAIN_FILE "$ENV{VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake" CACHE STRING "Vcpkg toolchain file")
注意这句话一定要在定义project名字之前,本例子是:project(CalculationInGrpcServer)
这样子后面的find_package, find_program, target_link_libraries等都会去vckpg里面找到。
cmake_minimum_required(VERSION 3.20)
# Note: 8 target(s) were omitted.
message("--------" $ENV{VCPKG_ROOT})set(CMAKE_TOOLCHAIN_FILE "$ENV{VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake" CACHE STRING "Vcpkg toolchain file")
project(CalculationInGrpcServer)set(_GRPC_GRPCPP gRPC::grpc++)
set(_PROTOBUF_LIBPROTOBUF protobuf::libprotobuf)
set(_REFLECTION gRPC::grpc++_reflection)set(_PROTOBUF_LIBPROTOBUF_D libprotobufd)
find_package(gRPC CONFIG REQUIRED)
find_program(_PROTOBUF_PROTOC protoc REQUIRED)
find_program(_GRPC_CPP_PLUGIN_EXECUTABLE grpc_cpp_plugin REQUIRED)# Generated proto sources
get_filename_component(proto "../proto/calculation.proto" ABSOLUTE)
get_filename_component(proto_name "../proto/calculation.proto" NAME_WE)
get_filename_component(proto_path "${proto}" PATH)set(proto_srcs "${proto_path}/${proto_name}.pb.cc")
set(proto_hdrs "${proto_path}/${proto_name}.pb.h")
set(grpc_srcs "${proto_path}/${proto_name}.grpc.pb.cc")
set(grpc_hdrs "${proto_path}/${proto_name}.grpc.pb.h")
message("------------------------------------------------")
message(${_PROTOBUF_PROTOC})
message(${_GRPC_CPP_PLUGIN_EXECUTABLE})
message(${proto_path})message("-------------------------------------------------")
add_custom_command(
OUTPUT "${proto_