[CMake/gRPC] 用CMake构建gRPC项目
[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})
| 欢迎来原网站坐坐! >原文链接<