当前位置: 首页 > article >正文

Windows下用CMake和VS编译gRPC 1.72.0,我踩过的那些坑(附完整依赖库列表)

Windows平台下gRPC 1.72.0编译实战从CMake配置到VS链接错误的系统化解法最近在Windows平台上手动编译gRPC 1.72.0的经历可谓是一波三折。作为一个长期在Linux环境下工作的开发者这次回到Windows平台进行gRPC编译遇到了不少特有的挑战。本文将详细记录整个编译过程中遇到的典型问题及其解决方案特别是那些在官方文档中没有明确说明的坑。1. 环境准备与源码获取在开始编译之前确保你的系统满足以下基本要求Windows 10/11 64位系统Visual Studio 2019或2022社区版即可CMake 3.15或更高版本Git for WindowsNASM汇编器用于某些加密库的编译获取gRPC源码的正确方式不是直接下载zip包而是使用Git克隆仓库并初始化子模块git clone --recurse-submodules -b v1.72.0 https://github.com/grpc/grpc cd grpc git submodule update --init --recursive注意--recurse-submodules参数至关重要它能确保所有依赖库如abseil-cpp、protobuf等被正确初始化。常见问题1子模块更新失败现象git submodule update命令执行后某些子模块仍然显示为空解决方案手动删除第三方库目录后重试或使用git submodule sync同步2. CMake配置的关键细节使用CMake生成VS项目文件时以下几个配置项需要特别注意配置变量推荐值说明CMAKE_CXX_STANDARD17gRPC 1.72.0需要C17支持gRPC_ABSL_PROVIDERmodule使用源码中的abseil而非系统安装的gRPC_PROTOBUF_PROVIDERmodule同上使用源码中的protobufBUILD_SHARED_LIBSOFF建议先编译静态库便于调试在CMake GUI中添加这些变量后点击Configure和Generate。如果遇到以下错误Could NOT find Protobuf (missing: Protobuf_LIBRARIES Protobuf_INCLUDE_DIR)这表明CMake正在尝试查找系统安装的protobuf而非使用子模块中的版本。解决方案是明确设置set(Protobuf_ROOT ${CMAKE_CURRENT_SOURCE_DIR}/third_party/protobuf)3. Visual Studio编译中的典型错误在VS中打开生成的解决方案后编译ALL_BUILD项目可能会遇到以下问题3.1 Abseil版本冲突最常见的错误是关于absl::lts_20250127::命名空间的链接错误error LNK2019: unresolved external symbol class absl::lts_20250127::...这个问题源于gRPC和系统中其他库使用的abseil版本不一致。解决方案有统一使用源码中的abseil确保gRPC_ABSL_PROVIDERmodule删除系统或vcpkg安装的abseil库手动替换abseil文件robocopy /E ..\abseil-cpp\absl third_party\abseil-cpp\absl修改编译选项 在CMakeLists.txt中添加add_compile_definitions(ABSL_LEGACY_THREAD_ANNOTATIONS)3.2 标准库兼容性问题当看到类似以下的错误时error C2039: source_location: is not a member of std这表明项目没有正确设置为C17标准。需要在CMake中明确指定set(CMAKE_CXX_STANDARD 17) set(CMAKE_CXX_STANDARD_REQUIRED ON)如果已经在CMake中设置但仍然无效需要在VS项目属性中手动修改右键项目 → 属性C/C → 语言 → C语言标准 → 选择ISO C17标准4. 依赖库管理与最终链接成功编译后在你的项目中集成gRPC时需要链接大量库文件。以下是经过验证的完整库列表按功能分类核心库grpc.libgrpc.libgpr.libaddress_sorting.libProtobuf相关libprotobufd.lib (Debug)libprotobuf.lib (Release)upb_*.lib (各种upb库)Abseil库共约60个以下是关键部分absl_base.lib absl_strings.lib absl_synchronization.lib absl_time.lib absl_hash.lib absl_cord.lib系统依赖ws2_32.lib (Windows sockets)crypt32.lib (加密API)advapi32.lib (安全相关)提示Debug和Release版本的库不能混用确保所有库文件来自同一构建配置。在实际项目中建议使用CMake的find_package来管理这些依赖find_package(gRPC CONFIG REQUIRED) target_link_libraries(MyProject PRIVATE gRPC::grpc)5. 替代方案与优化建议如果手动编译过程过于复杂可以考虑以下替代方案使用vcpkgvcpkg install grpc:x64-windows这种方式会自动处理所有依赖关系但灵活性较低。预编译二进制 从官方发布页面下载预编译的库文件但可能不包含所有需要的组件。Docker构建 在Linux容器中构建Windows版本可以避免许多环境问题。对于需要频繁编译的场景建议编写自动化脚本# build_grpc.ps1 $GRPC_ROOT path/to/grpc cmake -S $GRPC_ROOT -B $GRPC_ROOT/cmake_build -DCMAKE_BUILD_TYPERelease -DgRPC_INSTALLON -DABSL_PROPAGATE_CXX_STDON cmake --build $GRPC_ROOT/cmake_build --config Release --parallel 8经过三天断断续续的尝试和错误排查最终成功编译出可用的gRPC库。最大的教训是在Windows平台上环境隔离和版本一致性比Linux下更为关键。特别是那些看似无害的系统级依赖很可能成为编译失败的罪魁祸首。

相关文章:

Windows下用CMake和VS编译gRPC 1.72.0,我踩过的那些坑(附完整依赖库列表)

Windows平台下gRPC 1.72.0编译实战:从CMake配置到VS链接错误的系统化解法 最近在Windows平台上手动编译gRPC 1.72.0的经历可谓是一波三折。作为一个长期在Linux环境下工作的开发者,这次回到Windows平台进行gRPC编译,遇到了不少特有的挑战。本…...

【仅开放72小时】C++27实验性parallel_unstable_sort_view深度评测:多核排序吞吐达1.2GB/s的编译器flag调优矩阵(附Intel Xeon W9-3400实测数据)

第一章:C27实验性parallel_unstable_sort_view概览parallel_unstable_sort_view 是 C27 标准提案(P2903R3)中引入的实验性范围适配器,旨在为无序、高性能的并行排序提供轻量级视图封装。它不保证相等元素的相对顺序(即…...

【2024大厂AI基础设施面试压轴题】:手写Cuvil自定义Op注册+自动融合Pass(附可运行验证代码)

第一章:Cuvil 编译器在 Python AI 推理中的应用 面试题汇总Cuvil 是一款面向 AI 推理场景的轻量级领域专用编译器(DSL Compiler),专为优化 Python 中基于 PyTorch/TensorFlow 模型的部署而设计。它通过静态图重写、算子融合与硬件…...

GTE多任务NLP引擎部署教程:离线环境下的安装、配置与测试

GTE多任务NLP引擎部署教程:离线环境下的安装、配置与测试 1. 环境准备与快速部署 1.1 系统要求与依赖检查 在开始部署前,请确保您的离线服务器满足以下最低要求: 操作系统:Ubuntu 20.04/22.04 或 CentOS 7/8(推荐&…...

Phi-4-mini-reasoning应用场景:AI竞赛教练系统自动出题与解析

Phi-4-mini-reasoning应用场景:AI竞赛教练系统自动出题与解析 1. 引言:当AI遇见竞赛训练 想象一下,一位数学竞赛教练每天需要: 设计不同难度的题目准备详细的解题步骤针对学生错误提供个性化解析不断更新题库保持新鲜度 传统方…...

Ostrakon-VL-8B多模态能力解析:图文联合理解在零售场景的体现

Ostrakon-VL-8B多模态能力解析:图文联合理解在零售场景的体现 1. 零售场景中的多模态挑战 现代零售行业面临着复杂的视觉理解需求。传统计算机视觉系统通常只能完成单一任务,比如商品识别或文字提取,而无法同时理解图像中的多种元素及其相互…...

Wan2.1视频生成创意玩法:把你的想法变成动态视觉故事

Wan2.1视频生成创意玩法:把你的想法变成动态视觉故事 1. 从文字到视频的魔法 你有没有过这样的经历?脑海中浮现出一个绝妙的创意场景,却苦于没有专业的视频制作技能将它呈现出来。或许是一个科幻故事的开场,一个产品演示的构想&…...

Qwen3-0.6B入门实战:从镜像启动到智能问答,完整流程解析

Qwen3-0.6B入门实战:从镜像启动到智能问答,完整流程解析 1. Qwen3-0.6B简介 Qwen3(千问3)是阿里巴巴集团开源的新一代通义千问大语言模型系列,涵盖6款密集模型和2款混合专家(MoE)架构模型。Qw…...

Qwen3.5-9B-AWQ-4bit效果展示:高清截图OCR、场景描述、主体识别实测集

Qwen3.5-9B-AWQ-4bit效果展示:高清截图OCR、场景描述、主体识别实测集 1. 模型能力概览 Qwen3.5-9B-AWQ-4bit是一款基于量化技术的多模态视觉理解模型,能够同时处理图像和文本输入,输出高质量的中文分析结果。这个4bit量化版本在保持核心能…...

intv_ai_mk11效果实测:技术面试题生成能力——覆盖算法/系统设计/行为问题

intv_ai_mk11效果实测:技术面试题生成能力——覆盖算法/系统设计/行为问题 1. 测试背景与模型介绍 intv_ai_mk11是一款基于Llama架构的AI对话助手,拥有7B参数规模,专门针对技术场景进行了优化。本次测试聚焦于其在技术面试题生成方面的能力…...

机器人控制系统(RCS)核心算法深度解析:从路径规划到任务调度

在智能制造与智能物流快速发展的背景下,机器人控制系统(RCS)作为 AGV 集群的“大脑中枢”,其核心算法的设计与优化直接决定了整个系统的运行效率和稳定性。本文系统分析了 RCS 系统中的三大核心算法——​路径规划、冲突解决、任务…...

Phi-4-mini-reasoning vLLM模型服务化:gRPC接口与Protobuf定义详解

Phi-4-mini-reasoning vLLM模型服务化:gRPC接口与Protobuf定义详解 1. 模型概述 Phi-4-mini-reasoning 是一个基于合成数据构建的轻量级开源模型,专注于高质量、密集推理的数据处理。作为Phi-4模型家族的一员,它特别针对数学推理能力进行了…...

RCS 核心系统架构:AGV 调度“大脑”的底层逻辑

在现代智能物流与制造系统中,RCS(Robot Control System)作为 AGV 集群的核心调度中枢,扮演着"智慧大脑"的关键角色。不同于单台 AGV 的自主导航,RCS 需要解决多车协同、任务分配、路径规划与冲突避免等复杂问…...

Vertex AI 漏洞暴露谷歌云数据和非公开制品

聚焦源代码安全,网罗国内外最新资讯!编译:代码卫士网络安全研究人员披露称谷歌云 Vertex AI 平台中存在一个安全“盲点”,可使攻击者将人工智能代理武器化,从而未经授权访问敏感数据并危及组织机构的云环境安全。Palo …...

GLM-4.1V-9B-Base实战教程:批量图片队列处理与异步结果回调机制实现

GLM-4.1V-9B-Base实战教程:批量图片队列处理与异步结果回调机制实现 1. 引言 在实际业务场景中,我们经常需要处理大量图片的分析任务。GLM-4.1V-9B-Base作为一款强大的视觉多模态理解模型,虽然提供了便捷的Web界面,但面对批量图…...

小杰云商城系统源码/小程序源码平台/电商系统源码/完整版/全开源

小杰云商城系统源码 完整版 全开源 基于多款经典商城深度优化重构,不管是功能、颜值、安全、流畅度,直接给你干到天花板! 完美适配易支付V2和mapi支付,拿到手简单配置就能上线运营,不用你再费劲改接口! 功能多到爆炸&#xff0…...

造相-Z-Image代码实例:Streamlit双栏UI自定义参数调节逻辑解析

造相-Z-Image代码实例:Streamlit双栏UI自定义参数调节逻辑解析 1. 项目概述 造相-Z-Image是一个基于通义千问官方Z-Image模型的本地轻量化文生图系统,专门为RTX 4090显卡进行深度优化。该系统采用BF16高精度推理技术,具备显存极致防爆能力&…...

Phi-4-mini-reasoning部署避坑指南:CUDA OOM、端口映射、STARTING卡顿全解析

Phi-4-mini-reasoning部署避坑指南:CUDA OOM、端口映射、STARTING卡顿全解析 1. 模型简介 Phi-4-mini-reasoning是微软推出的3.8B参数轻量级开源模型,专为数学推理、逻辑推导和多步解题等强逻辑任务设计。这个模型主打"小参数、强推理、长上下文、…...

Qwen3.5-9B部署教程:CentOS 7兼容方案(glibc升级+systemd服务模板)

Qwen3.5-9B部署教程:CentOS 7兼容方案(glibc升级systemd服务模板) 1. 项目概述 Qwen3.5-9B是一款拥有90亿参数的开源大语言模型,具备强大的逻辑推理、代码生成和多轮对话能力。该模型支持多模态理解(图文输入&#x…...

ChatTTS语音合成生产环境部署:负载均衡+API服务化封装实践

ChatTTS语音合成生产环境部署:负载均衡API服务化封装实践 1. 项目背景与价值 ChatTTS是目前开源领域最逼真的中文语音合成模型之一,专门针对对话场景进行了深度优化。与传统的TTS系统不同,ChatTTS能够自动生成极其自然的停顿、换气声、笑声…...

bert-base-chinese新手必看:完形填空与语义相似度功能实测教程

bert-base-chinese新手必看:完形填空与语义相似度功能实测教程 1. 快速了解bert-base-chinese bert-base-chinese是Google发布的经典中文预训练模型,作为NLP领域的基础模型,它已经成为中文自然语言处理任务的标准选择之一。这个模型特别适合…...

SDMatte+在影视后期应用:绿幕替代方案探索、道具透明化处理与VFX资产快速提取

SDMatte在影视后期应用:绿幕替代方案探索、道具透明化处理与VFX资产快速提取 1. 影视后期中的抠图挑战 在影视后期制作中,高质量的抠图技术是视觉特效(VFX)的基础。传统绿幕拍摄虽然成熟,但存在诸多限制: 需要专门的拍摄场地和…...

Qwen3.5-2B轻量模型效果:20亿参数实现92%准确率的通用图文VQA任务

Qwen3.5-2B轻量模型效果:20亿参数实现92%准确率的通用图文VQA任务 1. 模型概述 Qwen3.5-2B是阿里云推出的轻量化多模态基础模型,属于Qwen3.5系列的小参数版本。这个仅20亿参数的模型在保持高性能的同时,显著降低了部署门槛和资源消耗。 核…...

Pixel Couplet Gen快速部署:微信小程序端调用像素春联API的跨域与性能优化

Pixel Couplet Gen快速部署:微信小程序端调用像素春联API的跨域与性能优化 1. 项目背景与核心价值 Pixel Couplet Gen是一款基于ModelScope大模型驱动的创新春联生成器,将传统春节文化与现代像素艺术完美融合。不同于传统春联生成工具,该项…...

MySQL 中 count(*)、count(1) 和 count(字段名) 有什么区别?

一、快速结论(先看结论再看分析)方式作用效率一句话总结count(*)统计所有行数⭐⭐⭐⭐ 最高我是专业的!我为统计而生count(1)统计所有行数⭐⭐⭐⭐ 同样高效我是 count(*) 的马甲兄弟count(列名)统计该列非 NULL 的行数⭐⭐⭐ 较慢我挑剔&…...

Pixel Aurora Engine 环境配置详解:Anaconda创建独立Python运行环境

Pixel Aurora Engine 环境配置详解:Anaconda创建独立Python运行环境 1. 为什么需要独立Python环境 在开始配置Pixel Aurora Engine的开发环境之前,我们先聊聊为什么需要创建独立的Python运行环境。想象一下,你的电脑就像一个大型工具箱&…...

Ivanti EPMM RCE CVE-2026-1340/1281完整分析

介绍:近日,Ivanti公司披露了Ivanti Endpoint Manager Mobile (EPMM)中存在的代码注入漏洞(CVE-2026-1281和CVE-2026-1340),并确认已存在在野利用。该漏洞源于 Apache HTTPd 调用的 Bash 脚本在处理时间戳比较时,未能有效过滤恶意参数&#xf…...

Python➕PyQt5➕numpy➕pandas实现学生成绩分析系统(可视化)基于 Python + PyQt5 + Matplotlib + Pandas 实现的学生成绩分析系统框架

基于 Python PyQt5 Matplotlib Pandas 实现的学生成绩分析系统框架 Python➕PyQt5➕numpy➕pandas实现学生成绩分析系统(可视化) (源码项目文档详细README) !!代码注释非常详细 !&#xff01…...

Python MCP服务可观测性革命:OpenTelemetry+Prometheus+Grafana三件套零代码接入方案(附完整YAML模板)

第一章:Python MCP服务可观测性革命概述在微服务架构持续演进的今天,Python构建的MCP(Metrics, Context, and Propagation)服务正成为可观测性实践的关键载体。传统日志聚合与单点监控已难以应对跨服务调用链中上下文丢失、指标语…...

Qwen3.5-9B-AWQ-4bit镜像免配置教程:无需conda/pip,7860端口直连使用

Qwen3.5-9B-AWQ-4bit镜像免配置教程:无需conda/pip,7860端口直连使用 1. 开箱即用的视觉理解模型 今天要介绍的是一个能"看懂"图片的AI模型——Qwen3.5-9B-AWQ-4bit。这个模型最厉害的地方在于,它不仅能理解文字,还能…...