首页
/ Rerun项目中SorbetColumnDescriptors字段顺序问题的技术解析

Rerun项目中SorbetColumnDescriptors字段顺序问题的技术解析

2025-05-27 18:41:37作者:宣海椒Queenly

背景介绍

在Rerun项目的存储系统中,SorbetBatch扮演着双重角色:一方面作为通用的Arrow记录批次包装器,另一方面作为记录批次与数据块(chunk)之间序列化的过渡方案。这种双重身份导致了当前代码中关于字段顺序的严格约束问题。

问题本质

问题的核心在于try_from_arrow_fields构建器对字段顺序有着严格要求。具体表现为代码中硬编码了对特定字段顺序的依赖,这与系统设计原则中的"接受用户或数据平台提供的任何输入"相违背。

技术影响

这种硬编码的字段顺序约束虽然从性能角度可以理解,但带来了以下问题:

  1. 限制了系统的灵活性,无法处理非标准顺序的输入数据
  2. 增加了与其他系统集成的难度
  3. 违背了鲁棒性设计原则

解决方案演进

项目团队经过讨论提出了几个阶段的解决方案:

第一阶段:临时修复

引入try_from_arrow_fields_forgiving作为临时解决方案,放宽对字段顺序的要求。但这只是治标不治本。

第二阶段:类型状态模式

考虑采用类型状态模式(Type State Pattern)来区分不同用途:

  • SorbetBatch<Flex>:通用包装器,对字段顺序无要求
  • SorbetBatch<Strict>:用于块序列化,保持严格顺序要求

第三阶段:最终设计方案

经过深入讨论后,团队决定采用更彻底的解决方案:

  1. 使SorbetBatch完全通用化,允许任意字段顺序
  2. 将顺序约束移至更严格的ChunkBatch
  3. 通过枚举明确区分不同类型的列描述符

实现细节

新的设计将包含以下关键组件:

pub enum ColumnDescriptor {
    RowId(RowIdColumnDescriptor),
    Time(IndexColumnDescriptor),
    Component(ComponentColumnDescriptor),
}

此外,SorbetBatch将增加.kind()方法,用于标识批次类型(Dataframe、Chunk或None)。同时提供:

  • ChunkBatch::try_from(SorbetBatch)转换方法
  • split_into_chunks()方法,用于将多实体记录批次分割为适合ChunkStore的块

架构意义

这一改进将使Rerun存储系统:

  1. 对外部输入更加宽容和健壮
  2. 内部处理逻辑更加清晰明确
  3. 为未来的扩展奠定更好基础
  4. 保持高性能的同时提高灵活性

总结

通过对SorbetColumnDescriptors字段顺序问题的深入分析和重构,Rerun项目将实现存储层更加优雅的设计,既满足了严格序列化场景的性能需求,又提供了处理任意输入数据的灵活性。这种分层设计思路值得在类似系统中借鉴。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
27
11
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
469
3.48 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
10
1
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
65
19
flutter_flutterflutter_flutter
暂无简介
Dart
716
172
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
208
83
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.27 K
695
rainbondrainbond
无需学习 Kubernetes 的容器平台,在 Kubernetes 上构建、部署、组装和管理应用,无需 K8s 专业知识,全流程图形化管理
Go
15
1
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
1