C++交叉编译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

猜你喜欢

转载自blog.csdn.net/simple_core/article/details/127408007