zl程序教程

您现在的位置是:首页 >  其他

当前栏目

[CMake/gRPC] 用CMake构建gRPC项目

项目 构建 CMake grpc
2023-09-11 14:15:24 时间

[CMake/gRPC] 用CMake构建gRPC项目

首先,gRPC的安装本身就是一件很麻烦的事。由于众所周知的原因,直接git clone gRPC是相当慢且成功率低的。目前个人的建议是在一个代理良好的环境中下载好gRPC,再通过scp传到其他服务器上。

如果你遵循着官网教程去安装gRPC,你应该会将它安装到本地目录下~/.local。如果你想在你的项目之中使用gRPC库,而且想用CMake去编译,你可以参考官网的例子:

grpc/CMakeLists.txt at master · grpc/grpc (github.com)

注:下面的修改都是基于上面这个代码之上的。

如果你的系统中已经安装好了protobuf和gRPC,那么不建议你再次安装它。因为在实际使用中你本地的gRPC和系统的gRPC可能会出现冲突。比如你在生成.pb.h文件时使用了系统自带的低版本protoc,但编译.pb.h时却用的是你本地的高版本grpc++,二者出现版本冲突。为了减少麻烦,建议你直接使用系统自带的低版本。

不用担心,gRPC的1.x.x版本都是互通的,一个装有低版本的gRPC服务器可以和一个装有高版本gRPC正常的通信。

如果你的gRPC安装在了~/.local或者/usr这种位置,cmake可以很容易地自动检测到它。但如果你的gRPC安装在了其他地方,你需要将其加入cmake的路径。

list(APPEND CMAKE_PREFIX_PATH $ENV{SDE_INSTALL})
include_directories($ENV{SDE_INSTALL}/include)
link_directories($ENV{SDE_INSTALL}/lib)
find_program(_GRPC_CPP_PLUGIN_EXECUTABLE grpc_cpp_plugin)

set(_GRPC_GRPCPP grpc++)
set(_REFLECTION grpc++_reflection)
find_program(_PROTOBUF_PROTOC protoc)
set(_PROTOBUF_LIBPROTOBUF protobuf)

最后,建议将生成所有的.pb.xx文件包装成一个库。如果一个程序想要使用grpc,只需要用target_link_libraries链接这个库即可。

# Include generated *.pb.h files
include_directories("${CMAKE_CURRENT_BINARY_DIR}")

# Add library
add_library(grpc_proto
    ${grpc_srcs}
    )
    
target_link_libraries(grpc_proto PUBLIC
    ${_REFLECTION}
    ${_GRPC_GRPCPP}
    ${_PROTOBUF_LIBPROTOBUF})