Parallel Hashmap在大规模数据集中的性能优化实践
2025-06-27 13:01:58作者:冯梦姬Eddie
parallel-hashmap
A family of header-only, very fast and memory-friendly hashmap and btree containers.
背景介绍
在使用Parallel Hashmap(phmap)实现LSH Forest数据结构时,遇到了处理超大规模数据集(8600万条2048维向量)的挑战。由于数据量远超内存容量,需要将哈希表分割存储到多个约6GB的文件中,并寻求更高效的序列化/反序列化方案。
技术挑战分析
项目中使用的哈希表类型为phmap::flat_hash_map<std::vector<uint8_t>, std::vector<uint32_t>>,这种结构存在两个主要性能瓶颈:
- 数据类型限制:标准库的
std::vector不是可平凡复制(trivially_copyable)类型,无法直接使用phmap内置的高效序列化功能 - 文件IO性能:每个文件的加载时间约4秒,对于需要频繁访问的场景来说性能不足
解决方案探索
方案一:改用std::array
仓库作者建议如果键值大小固定,可使用std::array替代std::vector。std::array是可平凡复制类型,能够利用phmap内置的phmap_dump功能实现高效序列化。
但实际场景中:
- 值部分存储的是动态变化的索引数据,必须使用动态容器
- 键部分虽然原始数据维度固定(2048),但经过哈希处理后大小会变化
方案二:自定义二进制存储
最终采用的解决方案是绕过序列化框架,直接实现自定义的二进制文件存储:
- 将哈希表内容手动写入二进制文件
- 运行时直接加载二进制数据
- 完全避免了序列化/反序列化开销
这种方案显著提升了IO性能,特别适合以下场景:
- 数据结构稳定,不频繁变更
- 需要极致的加载速度
- 数据量远超内存容量
技术启示
- 容器选择:在性能敏感场景中,固定大小容器(
std::array)比动态容器(std::vector)有优势 - 序列化权衡:通用序列化框架虽然方便,但特定场景下手写二进制IO可能更高效
- 内存管理:处理超大数据集时,分块存储和按需加载是必要策略
总结
通过这次优化实践,我们认识到在超大规模数据处理中,需要根据具体场景灵活选择技术方案。Parallel Hashmap提供了优秀的性能基础,但在极端场景下,结合自定义存储方案才能发挥最大效能。这也体现了系统设计中"没有银弹"的原则,需要根据实际需求做出合理权衡。
parallel-hashmap
A family of header-only, very fast and memory-friendly hashmap and btree containers.
登录后查看全文
热门项目推荐
相关项目推荐
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0100
baihu-dataset异构数据集“白虎”正式开源——首批开放10w+条真实机器人动作数据,构建具身智能标准化训练基座。00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python059
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7GLM-4.7上线并开源。新版本面向Coding场景强化了编码能力、长程任务规划与工具协同,并在多项主流公开基准测试中取得开源模型中的领先表现。 目前,GLM-4.7已通过BigModel.cn提供API,并在z.ai全栈开发模式中上线Skills模块,支持多模态任务的统一规划与协作。Jinja00
AgentCPM-Explore没有万亿参数的算力堆砌,没有百万级数据的暴力灌入,清华大学自然语言处理实验室、中国人民大学、面壁智能与 OpenBMB 开源社区联合研发的 AgentCPM-Explore 智能体模型基于仅 4B 参数的模型,在深度探索类任务上取得同尺寸模型 SOTA、越级赶上甚至超越 8B 级 SOTA 模型、比肩部分 30B 级以上和闭源大模型的效果,真正让大模型的长程任务处理能力有望部署于端侧。Jinja00
最新内容推荐
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
477
3.56 K
React Native鸿蒙化仓库
JavaScript
287
340
暂无简介
Dart
728
175
Ascend Extension for PyTorch
Python
287
320
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
849
446
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
235
98
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
10
1
TorchAir 支持用户基于PyTorch框架和torch_npu插件在昇腾NPU上使用图模式进行推理。
Python
450
180
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.28 K
705