Apache Horaedb 远程通信序列化方案优化实践
2025-06-29 09:49:24作者:卓艾滢Kingsley
背景
Apache Horaedb 是一个高性能的时序数据库,在其分布式架构中,不同服务器节点之间通过 gRPC 进行通信。当前实现中,RemoteEngineService 使用 Protocol Buffers 作为序列化方案,但在生产环境中观察到了较高的 CPU 使用率。
问题分析
Protocol Buffers 虽然广泛使用,但在性能方面存在一些不足:
- 编码/解码过程需要额外的 CPU 计算
- 内存布局与传输格式不一致,存在序列化/反序列化开销
- 对于高吞吐场景,这些开销会显著影响系统整体性能
解决方案探索
团队评估了多种现代序列化方案,重点关注以下特性:
- 零拷贝技术:内存布局与传输格式一致,减少转换开销
- 原生 Rust 支持:与现有代码库无缝集成
- Tonic 兼容性:能够与现有 gRPC 框架协同工作
经过详细基准测试,最终选择了 FlatBuffers 作为替代方案。测试结果表明:
- FlatBuffers 提供了最佳性能表现
- 完美支持零拷贝特性
- 可以很好地与 Tonic 集成
实施策略
考虑到实际影响和改造成本,团队决定采用渐进式优化策略:
- 优先优化 write API:生产环境中观察到该接口的 CPU 消耗最为明显
- 保持接口兼容性:确保升级过程平滑,不影响现有功能
- 分阶段实施:先验证核心功能,再逐步扩展优化范围
技术实现要点
在 RemoteEngineService 的实现中,关键改造点包括:
- 重写数据结构的序列化/反序列化逻辑
- 调整 gRPC 消息格式定义
- 优化内存管理策略,充分利用零拷贝特性
- 性能监控和调优
预期收益
通过这次优化,预期将获得以下改进:
- 显著降低 CPU 使用率,特别是在高负载场景下
- 提高系统整体吞吐量
- 减少序列化/反序列化带来的延迟
- 更高效的内存利用率
总结
Apache Horaedb 通过采用 FlatBuffers 替代 Protocol Buffers,有效解决了分布式通信中的性能瓶颈问题。这种优化不仅提升了系统性能,也为后续的性能调优工作提供了宝贵经验。对于类似的高性能数据库系统,选择合适的序列化方案对整体性能有着至关重要的影响。
登录后查看全文
热门项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0191
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0118
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
fun-rec推荐系统入门教程,在线阅读地址:https://datawhalechina.github.io/fun-rec/Python03
so-large-lm大模型基础: 一文了解大模型基础知识01
项目优选
收起
暂无描述
Dockerfile
764
4.98 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
857
1.93 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
683
1.33 K
Ascend Extension for PyTorch
Python
719
882
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.08 K
1.1 K
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
457
439
用户可使用该项目在 OpenHarmony 平台开发应用,支持通过 IDE 或终端用 Flutter Tools 指令编译构建,基于 Flutter 3.27.4 版本,新增 impeller-vulkan 渲染模式,兼容多种开发指令与环境配置。
Dart
1.01 K
261
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
151
253
CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。
Python
998
609