【安装】grpc源码编译安装(Windows)

本文详细介绍了如何在Windows环境下编译gRPCV1.58.0,包括设置编译环境(如CMake和VS2019),处理stdalign.h错误,以及样例程序的编译步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、编译环境说明

    1. grpc版本: V1.58.0
    1. cmake版本:3.8或以上(当前使用cmake version 3.20.21032501-MSVC_2)
    1. IDE:VS2019
    1. nasm版本: 2.16.01

二、编译环境准备

    1. 安装VS Studio 2019 或以上版本;
    1. 安装CMake 3.8或以上版本;
    1. 安装nasm,并将nasm 安装目录设置到PATH环境变量;

三、源码下载

# 注意:下载子模块时因github对应源码不在国内服务器,下载会很慢,最好使用梯子
git clone --recurse-submodules -b v1.58.0 --depth 1 --shallow-submodules https://github.com/grpc/grpc

四、源码编译安装gRPC和Protocol Buffers

1. 新建编译目录

  • 在grpc根目录下新建.build文件夹

2. 设置cmake参数并生成解决方案

  • cmake … -G “Visual Studio 16 2019” -DgRPC_INSTALL=ON -DgRPC_BUILD_TESTS=OFF -DCMAKE_INSTALL_PREFIX=F:\grpc
  • 执行cmake后,会在.build目录下生成grpc.sln解决方案文件

3. 编译

  • 3.1 打开vs2019,选择 .build/grpc.sln 文件,打开解决方案
  • 3.2 右键单击ALL_BUILD,选择生成,开始编译。
    解决方案
  • 3.3 错误处理

    fatal error C1083: 无法打开包括文件: “stdalign.h”: No such file or directory
    编译报错

      1. 错误产生原因分析

      因为 <stdalign.h> 定义了作为 C++ 中的关键字的宏,所以包括它没有任何效果。 <stdalign.h> 在 C++ 中已弃用。 在 C++17 中已弃用,并在草案 C++20 标准中已删除。

      1. 解决办法
      • 修改报错对应的项目设置,将C语言标准由"ISO C11 标准 (/std:c11)"修改为“默认(旧MSVC)”
        项目设置
      • 右键单击ALL_BUILD,选择生成,重新开始编译。
  • 3.4 编译完成
    编译完成

4. 生成

选择INSTALL,右键单击,生成。
注意:在设置cmake参数的时候,需要通过 -DCMAKE_INSTALL_PREFIX=your_install_dir,指定安装目录。如果不指定,默认是安装在C:\Program Files (x86)\grpc路径下。如果安装在C盘,需要使用管理员打开解决方案,不然生成的时候会因为权限原因失败。
生成

5. 查看安装目录生成的文件

生成文件

五、样例程序编译(使用已有CMakeLists.txt,全部编译)

1. 打开examples中的helloworld项目

  • 使用vs2019,选择打开cmake项目;
  • 然后选中 grpc\examples\cpp\helloworld\CMakeLists.txt 文件打开项目

2.设置cmake参数,指定搜索路径

  • 在打开的项目中,右键选择"HelloWorld的CMake"设置,打开cmake设置。
    cmake设置
  • 因为CMAKE设置未显示CMAKE_PATH_PREFIX变量,需要修改CMakeSettings.json文件
    CMakeSettings.json文件编辑
  • 查看添加成功的cmake参数
    设置cmake参数

3. 生成

  • 选择工具栏“生成—全部生成”,生成项目
    生成项目
  • 查看生成结果文件
    结果文件
    结果文件2
<think>好的,用户想了解在Windows编译gRPC的方法。首先,我需要回忆gRPC编译步骤,确保信息准确。可能涉及安装CMake、Visual Studio,以及使用vcpkg或者直接从源码编译。要分步骤说明,可能还需要注意事项,比如依赖项、路径设置等。 用户可能是开发者,可能在Windows环境下需要搭建gRPC进行开发或测试。需要明确编译前的准备工作,比如安装必要的工具链,确保用户不会遗漏。可能需要提到不同的编译方法,比如使用CMake直接编译或者借助包管理器vcpkg,这样用户可以根据自己的情况选择。 另外,用户可能遇到常见问题,比如网络问题下载依赖失败,或者编译过程中的错误处理。需要给出一些提示,比如设置代理、检查路径等。还要注意版本兼容性,比如Visual Studio的版本是否支持,CMake版本是否足够新。 可能需要分步骤详细说明,每一步都给出具体的命令或操作,确保用户能跟随操作。同时,语言要简洁明了,避免使用过于专业的术语,或者解释清楚术语。例如,解释vcpkg是什么,以及为什么要使用它。 还要考虑用户可能的最终需求,比如编译后如何测试是否成功,或者如何将gRPC集成到自己的项目中。是否需要提供简单的示例代码或编译后的库的使用方法? 最后,检查是否有最新的变化,比如gRPC的版本更新导致编译步骤不同,或者Windows系统的新要求。可能需要参考官方文档的最新指南,确保提供的信息不过时。 总结下来,回答的结构应该是先介绍准备工作,然后分方法详细说明步骤,最后给出测试和常见问题处理。这样用户能一步步跟随,顺利完成编译。</think>在 Windows编译 gRPC 需要一些准备工作,以下是详细步骤和注意事项: --- ### **一、准备工作** 1. **安装 Visual Studio** 推荐使用 **Visual Studio 2019 或更高版本**,安装时需勾选: - "Desktop development with C++"(C++桌面开发) - "Windows 10/11 SDK" 2. **安装 CMake** 从 [CMake 官网](https://cmake.org/download/) 下载并安装最新版本(≥3.15),安装时勾选 **"Add to PATH"**。 3. **安装 Git** 用于克隆 gRPC 仓库和子模块管理。 4. **可选工具:vcpkg(推荐)** 微软的 C++ 包管理器,可简化依赖管理: ```bash git clone https://github.com/microsoft/vcpkg .\vcpkg\bootstrap-vcpkg.bat ``` --- ### **二、编译方法(两种常见方式)** --- #### **方法 1:使用 CMake 直接编译** **步骤:** 1. **克隆 gRPC 仓库** ```bash git clone --recurse-submodules https://github.com/grpc/grpc.git cd grpc ``` 2. **生成构建文件** 打开 PowerShell 或 CMD,执行: ```bash mkdir cmake_build cd cmake_build cmake .. -G "Visual Studio 16 2019" -A x64 ``` - 替换 `-G` 参数为你的 Visual Studio 版本(如 `"Visual Studio 17 2022"`) - `-A x64` 指定生成 64 位库,也可用 `Win32` 编译 32 位。 3. **编译项目** ```bash cmake --build . --config Release ``` 编译后的库文件会生成在 `cmake_build/Release` 目录。 --- #### **方法 2:使用 vcpkg 安装(推荐)** 1. **安装 gRPC 依赖** ```bash .\vcpkg\vcpkg install grpc:x64-windows ``` - 若需静态库:`grpc:x64-windows-static` - 若需 32 位:`grpc:x86-windows` 2. **集成到 Visual Studio** ```bash .\vcpkg\vcpkg integrate install ``` 之后在 Visual Studio 项目中可直接引用 gRPC。 --- ### **三、验证安装** 1. **运行示例代码** gRPC 仓库的 `examples/cpp/helloworld` 目录包含测试项目,尝试编译并运行。 2. **检查生成的文件** 确保以下关键文件存在: - `grpc++.lib`、`grpc++_reflection.lib`(库文件) - `protoc.exe`(Protocol Buffers 编译器) - `grpc_cpp_plugin.exe`(gRPC 代码生成插件) --- ### **四、常见问题** 1. **子模块下载失败** 使用 `git submodule update --init --recursive` 手动拉取子模块,或配置代理: ```bash git config --global http.proxy http://your-proxy:port ``` 2. **CMake 报错** - 确保 Visual Studio 的 C++ 组件已安装。 - 升级 CMake 到最新版本。 3. **链接错误** 检查项目配置中的库路径(`include` 和 `lib` 目录)是否正确。 --- ### **五、后续步骤** - **代码生成**:使用 `protoc` 和 `grpc_cpp_plugin` 编译 `.proto` 文件。 - **项目配置**:在 Visual Studio 中设置头文件路径、库路径及依赖项(如 `zlib`、`openssl`)。 如需更详细的指导,可参考 [gRPC 官方 Windows 编译文档](https://github.com/grpc/grpc/blob/master/BUILDING.md)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值