C++交叉编译grpc

本文详细介绍了如何在Linux环境下,为ARM架构进行C++的gRPC交叉编译,包括安装依赖(如OpenSSL和CMake)、构建protoc工具、配置交叉编译文件、编译gRPC以及解决编译过程中的问题。文章还提到了在编译完成后,测试gRPC示例以及遇到的动态链接错误,并给出了如何选择合适的交叉编译器来解决这个问题。

下载源代码

下载源代码的时候一定要下载第三方库,怎么下载可以参考我之前的文章
《使用C++在window上的编译与安装grpc》

安装依赖

install openssl

可以查看一下自己是否安装了openssl version
在这里插入图片描述
没有的话安装:

//# Install openssl (to use instead of boringssl)
apt-get update && apt-get install -y libssl-dev

Install CMake 3.16

cmake的版本一定要大于3.16的版本

apt-get update && apt-get install -y wget
wget -q -O cmake-linux.sh https://github.com/Kitware/CMake/releases/download/v3.16.1/cmake-3.16.1-Linux-x86_64.sh
sh cmake-linux.sh -- --skip-license --prefix=/usr
rm cmake-linux.sh

设置
GRPC_CPP_DISTRIBTEST_BUILD_COMPILER_JOBS=${GRPC_CPP_DISTRIBTEST_BUILD_COMPILER_JOBS:-4}

构建protoc

这个是一定要先去构建的,因为后面的grpc的构建,我们要使用到。

# Build and install gRPC for the host architecture.
# We do this because we need to be able to run protoc and grpc_cpp_plugin
# while cross-compiling.
//进入grpc的源代码文件夹
mkdir -p "cmake/build"			//新建一个文件夹,用来存储编译过程中中的二进制文件
pushd "cmake/build"				//进入文件夹
cmake \
  -DCMAKE_BUILD_TYPE=Release \	//选择release模式构建
  -DgRPC_INSTALL=ON \			//是否安装
  -DgRPC_BUILD_TESTS=OFF \		//是否构建测试
  -DgRPC_SSL_PROVIDER=package \	//
  ../..
make "-j${GRPC_CPP_DISTRIBTEST_BUILD_COMPILER_JOBS}" install

如果自己构建的时候出现了c++的编译器错误的问题,就是多线程编译的时候出现了问题,我们-j的参数就不要了。

编写工具编译文件

cat > /tmp/toolchain.cmake <<'EOT'  						//在/tmp目录下新建一个文件toolchain.cmake
SET(CMAKE_SYSTEM_NAME Linux)								//设置系统为 linux
SET(CMAKE_SYSTEM_PROCESSOR aarch64)							//设置了目标程序的架构为arm64位
set(CMAKE_STAGING_PREFIX /tmp/stage)						//设置了安装路径		
set(CMAKE_C_COMPILER /usr/bin/aarch64-linux-gnu-gcc-6)		//设置c编译器
set(CMAKE_CXX_COMPILER /usr/bin/aarch64-linux-gnu-g++-6)	//设置了c++编译器
set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)				//设置了文件的查找路径
set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
set(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY)
EOT

开始编译grpc

# Build and install gRPC for ARM.
# This build will use the host architecture copies of protoc and
# grpc_cpp_plugin that we built earlier because we installed them
# to a location in our PATH (/usr/local/bin).
mkdir -p "cmake/build_arm"								//新建文件夹
pushd "cmake/build_arm"
cmake -DCMAKE_TOOLCHAIN_FILE=/tmp/toolchain.cmake \		//设置使用的交叉编译的文件
      -DCMAKE_BUILD_TYPE=Release \						//设置编译的模式为release
      -DCMAKE_INSTALL_PREFIX=/tmp/install \
      ../..
make "-j${GRPC_CPP_DISTRIBTEST_BUILD_COMPILER_JOBS}" install

如果编译的过程中出现了c++的编译器出现错误,就取消-j的参数,直接make就行。

测试和调用grpc

# Build helloworld example for ARM.
# As above, it will find and use protoc and grpc_cpp_plugin
# for the host architecture.
mkdir -p "examples/cpp/helloworld/cmake/build_arm"
pushd "examples/cpp/helloworld/cmake/build_arm"
cmake -DCMAKE_TOOLCHAIN_FILE=/tmp/toolchain.cmake \
      -DCMAKE_BUILD_TYPE=Release \
      -Dabsl_DIR=/tmp/stage/lib/cmake/absl \
      -DProtobuf_DIR=/tmp/stage/lib/cmake/protobuf \
      -DgRPC_DIR=/tmp/stage/lib/cmake/grpc \
      ../..
make "-j${GRPC_CPP_DISTRIBTEST_BUILD_COMPILER_JOBS}"

项目构建成功之后就可以直接在arm上,运行服务器和客户端。

错误:

在自己编译好,准备调用的时候,出现了错误
libc.so.6 的版本找不到。
这个是因为我arm上的系统的版本还有信息是不匹配的,我使用的交叉编译器的版本是比较新的。
这种情况的时候,我就只能是换旧的交叉编译器了,就没有自己去官网下载,而是依赖了系统的自己的安装。

32位的交叉编译工具链

sudo apt-get install gcc-arm-linux-gnueabihf

安装完之后,就可以使用编译命令:arm-linux-gnueabihf-gcc

64位的交叉编译工具链

sudo apt-get install gcc-aarch64-linux-gnu

安装完之后,就可以使用编译命令:aarch64-linux-gnu-gcc

### gRPC 交叉编译指南 gRPC交叉编译涉及多个步骤,主要关注点在于如何正确配置目标平台的工具链以及确保所需的依赖项已成功构建。以下是关于 gRPC 交叉编译的关键要点: #### 1. 准备阶段 在开始 gRPC交叉编译前,需完成以下准备工作: - **交叉编译 Protobuf** gRPC 跨平台编译的前提是先为宿主机和目标机分别生成 protobuf 和 gRPC 工具链。这是因为 gRPC 编译过程中会调用 protoc 和 grpc_cpp_plugin 等二进制文件[^1]。 - **设置交叉编译工具链** 使用 CMake 进行 gRPC 构建时,需要指定目标平台的工具链文件。通过 `-DCMAKE_TOOLCHAIN_FILE` 参数传递工具链路径。 #### 2. 配置 CMake 变量 为了支持跨平台编译,CMake 中应定义如下变量: - `CMAKE_SYSTEM_NAME`: 设置为目标操作系统名称(如 Linux、Windows)。 - `CMAKE_C_COMPILER` 和 `CMAKE_CXX_COMPILER`: 指定目标平台使用的 GCC/Clang 编译器路径。 - `CMAKE_FIND_ROOT_PATH`: 定义根目录以定位目标平台上的库和头文件。 示例命令如下: ```bash cmake -DgRPC_BUILD_TESTS=OFF \ -DCMAKE_POSITION_INDEPENDENT_CODE=ON \ -DCMAKE_TOOLCHAIN_FILE=/path/to/toolchain.cmake \ /path/to/grpc/source ``` #### 3. 处理常见错误 如果遇到类似于 “No rule to make target `_gRPC_CPP_PLUGIN-NOTFOUND'” 的错误,则表明未找到合适的 grpc_cpp_plugin 文件[^2]。解决方法包括: - 确认插件是否已在宿主机上正确生成。 - 将生成的插件复制到目标平台上,并调整 PATH 或 LD_LIBRARY_PATH 环境变量以便于识别。 #### 4. 测试与验证 完成编译后,在目标设备上测试生成的可执行文件或共享库的功能性至关重要。可以编写简单的客户端和服务端程序来验证通信逻辑是否正常运作。 --- ### 示例代码片段 下面是一个基本的 C++ Hello World 应用程序作为测试案例: ```cpp #include <iostream> #include "helloworld.grpc.pb.h" using grpc::Server; using grpc::ServerBuilder; using grpc::ServerContext; class GreeterService final : public helloworld::Greeter::Service { public: ::grpc::Status SayHello(ServerContext* context, const helloworld::HelloRequest* request, helloworld::HelloReply* reply) override { std::string prefix("Hello "); reply->set_message(prefix + request->name()); return ::grpc::Status::OK; } }; void RunServer() { std::string server_address("0.0.0.0:50051"); GreeterService service; 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(); } int main(int argc, char** argv) { RunServer(); return 0; } ``` 此代码展示了如何基于自动生成的服务接口实现服务器端业务逻辑。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值