成熟稳定:全面提升的成熟度级别和大查询稳定性
为了帮助用户更好地理解和使用新功能,StarRocks 3.3 对各项新特性进行了成熟度级别的划分,并采用了更清晰的标记体系:Experimental(实验性质)、Preview(公测阶段)和 GA(生产可用)。这种分级体系使用户能够根据功能的成熟度来决定是否在生产环境中使用。
Experimental(实验性质):这些功能的接口可能会变动,甚至可能被调整或放弃,部分刚合入社区的代码覆盖率尚未达到标准的功能也会先放入这一类别。此类功能需要用户手动打开或主动调用,不会影响其他功能。 Preview(公测阶段):接口基本稳定,但部分参数的语义可能会有微调。可以在非核心场景下使用。 GA(Gerneal available):接口和功能已经明确,虽然还会有一些功能补充,但已有功能基本不会修改,完全达到生产可用状态。
此外,为了进一步提升用户体验,我们针对数据湖分析、存算分离和物化视图等关键功能提供了更完整的产品能力边界和版本对照文档,方便用户理解和使用。
性能提升:新架构,新台阶,新场景
StarRocks 3.3 的发布不仅提升了基础性能,更在真实场景中的性能优化上迈上了新台阶。我们不仅仅拘泥于Benchmark 测试的成绩,而是专注于在实际应用中的性能提升。
首先,在新架构性能优化方面,StarRocks 对 ARM 架构进行了大幅优化,相比 x86 平均成本降低 20%,同时查询性能提升20%,使其成为与 x86 架构同等重要的一等公民。在 AWS Graviton 实例上的测试中,ARM 架构的性能提升显著:在 SSB 100G 测试中,ARM 比 x86 快 11%;在 Clickbench 测试中,ARM 比 x86 快 39%;在 TPCH 100G 测试中,ARM 比 x86 快 13%;在 TPCDS 100G 测试中,ARM 比 x86 快 35%。
在数据湖性能优化方面,StarRocks 3.3 提升了 Scan 性能,通过对 Page Index 的优化显著减少了 Scan 的数据规模,降低了 Page 多读的情况。此外,元数据性能也有了突破,显著提升了整体的处理效率。
针对特定场景的性能提升,StarRocks 3.3 进行了多方面的优化:
倒排索引和 ngram 索引的增强显著提升了模糊搜索的效率; FlatJson 对半结构化数据的处理性能也得到了百倍的显著提升,自动加速了 JSON 查询,使其性能接近结构化数据,同时保持了灵活性。 Bitmap 优化不仅提升了 Bitmap 系列函数的性能和内存占用,还补充了 Bitmap 导出到 Hive 的能力,以及相应的Hive Bitmap UDF。 CodeGen 技术显著提升了复杂表达式的计算效率,而重构后的向量化正则表达匹配也大幅降低了 regexp_replace 函数的 CPU 消耗。 为了应对数据倾斜问题,StarRocks 3.3 增加了外表统计信息中的直方图统计,使得在数据倾斜情况下能生成更准确的执行计划,并优化了数据倾斜时的 Shuffle Join 操作。 此外,全局字典的优化提供了字典对象,可以在各个 BE 节点内存中存储字典表的键值对映射关系通过dictionary_get() 函数直接查询维度值,相对于原先通过 JOIN 维度表获取维度值的方式,查询效率更高。
缓存设计:Lakehouse 架构的最后一块拼图
StarRocks 原生开发的缓存功能为用户提供了开箱即用的便捷体验。无需复杂的配置,用户即可利用强大的缓存机制提升数据处理性能。StarRocks 3.3 通过一系列创新功能显著提升了缓存的能力:
预热缓存:通过 cache warmup 命令,可以预先将关键数据加载到缓存中,减少首次查询的延迟。 缓存优先级:3.3.1 推出将 cache select 设置较高的缓存优先级,确保最重要的数据得到优先缓存。 内存优化和可观测性:缓存的内存优化和可观测性的提升,使得缓存的管理和监控更加高效和透明。
在存算分离集群中,StarRocks 3.3 还适配了AWS Express One Zone Storage,大幅提升了读写性能,为未来的全局缓存带来了全新的可能性。
物化视图:连接湖仓的高效纽带
物化视图作为 StarRocks 的核心能力,也是连接 Open lake format 和 StarRocks 内表的纽带。通过外表物化视图,可以透明地为数据湖上的查询进行加速,在保证 single source of truth 的同时,降低数据加工的复杂度。
在 3.3 版本中,我们又进一步做了一些重要优化:
外表物化视图的进一步能力增强:Iceberg 外表物化视图支持分区级别增量刷新,并可在分区方式为 Hidden Partition 的表上创建物化视图。Paimon 外表物化视图补全了改写能力,也支持了分区级别的增量刷新。 更完善的透明改写能力: StarRocks 3.3 支持了基于文本[1] 和视图[2] 的物化视图改写。 除了原来标准 SJPG 的改写能力之外,基于视图的 MV 改写可以把针对视图的查询改写到对等的物化视图上,适用于建模和指标平台等场景。针对文本的改写能力能对一些非标准 SQL 片段进行文本匹配,解决复杂查询难以透明改写的问题。
多事实表分区刷新优化[3] :此前,物化视图的分区刷新策略仅支持单个事实表增量刷新策略(即当物化视图的分区列和一个 base 表的分区列一致场景下,物化视图的刷新会根据base表的分区来进行变更),3.3 版本新增的多事实表对齐策略,可以降低多事实表关联场景下的物化视图刷新开销。
新增改写策略(Transparent MV):此前,物化视图的改写主要是把针对 base 表的查询改写到物化视图上,通过开启物化视图属性 transparent_mv_rewrite_mode
后,当用户直接查询物化视图时,StarRocks 会自动改写查询,将已经刷新的物化视图分区中的数据和未刷新分区对应的原始数据做自动 Union 合并。此模式允许配置在 MV 和 base 表数据不一致时的改写行为,实现在数据时效性和查询性能之间的权衡,适用于分层建模场景。开启物化视图属性 transparent_mv_rewrite_mode
后,当用户直接查询物化视图时,StarRocks 会自动改写查询,将已经刷新的物化视图分区中的数据和未刷新分区对应的原始数据做自动 Union 合并。大规模物化视图调度能力优化:增加 ena
ble_query_rewrite
属性,实现对查询改写的禁用,减少计划开销。通过控制候选物化视图数量,并引入更高效的筛选算法,增加物化视图计划缓存(MV plan cache)。支持全局 FIFO 调度,优化嵌套物化视图的级联刷新策略。
存储优化:更高效易用的数据管理
StarRocks 3.3 在存储优化与易用性提升方面做出了诸多改进,进一步增强了系统的性能和用户体验。
首先,StarRocks 3.3 提升了 FE 的可观测性和锁机制优化。提供了详细的内存使用指标,让用户可以更好地管理和监控资源。同时,引入了锁管理器(Lock Manager),实现对元数据锁的集中管理,将元数据锁的粒度从库级别细化为表级别。这种细化显著提高了导入和查询的并发性能,在 100 并发的导入场景下,导入耗时减少了 35%。
为了增强建表语句的清晰度,StarRocks 3.3 支持了 ORDER BY 语法,使得建表操作更加直观和简洁。此外,还增加了对重命名列(Rename Column)的支持(版本 3.3.1),进一步提升了数据管理的灵活性。
在存储效率方面,StarRocks 3.3 优化了非字符串标量类型数据的存储方式,存储空间下降了 12%。这不仅降低了存储成本,也提升了数据读取的效率。
针对主键表,StarRocks 3.3 实施了多项优化:
PK Index 存算分离支持 Remote Storage:主键索引落盘支持落至远程存储,提高了数据的灵活性和可扩展性。 主键表支持 Size-tiered Compaction 策略:这一策略降低了执行 Compaction 时的写 I/O 和内存开销,适用于存算分离和存算一体的集群。 优化主键表持久化索引的读 I/O:支持按照更小的粒度页读取持久化索引,并改进了持久化索引的 Bloom Filter。这一优化也适用于存算分离和存算一体的集群。
生态支持:Lakehouse 扩展与集成
Hive 生态支持:在3.3版本中,StarRocks 支持对 ORC 和 Text 文件的写入能力。单 sink 算子的写入性能达到了Trino 的 2 倍。
Iceberg 生态支持:StarRocks 3.3 大幅重构了 Iceberg 元数据查询模块,通过分布式元数据读取提升对 Avro 格式文件的解析性能,避免原生 SDK 的单点瓶颈,对小规模的元数据通过 manifest 缓存来降低重复 I/O,从而大幅提升了Iceberg 的元数据访问性能。同时,增加了对 V2 表 equality delete 的支持,使用户能够高效分析使用 Flink 写入的Iceberg upsert 数据。此外,还引入了对 Iceberg 视图(Iceberg View)的查询支持,使得数据管理和查询更加便捷和直观。
Paimon 生态支持:StarRocks 3.3 现已全面支持 Paimon 生态系统,包括对最新的 delete vector 的支持、Paimon 系统表的集成以及 scan range 调度的优化。通过这些改进,用户可以更高效地管理和查询 Paimon 中的数据,实现更灵活的数据处理和分析。
总结:成熟的 Lakehouse 架构
StarRocks 正在积极向成熟的湖仓架构升级,不仅增强了与开放湖格式的兼容性,还显著提升了湖的写入性能。在数仓功能上,它进一步加强了索引和半结构化数据处理的性能,同时,存算分离架构成为更受青睐的成熟解决方案。
此外,大查询和 ETL 任务的稳定性的提高,为批处理的能力打下基础。这些进步共同推动了 StarRocks 向一套架构,满足所有的分析需求的"One data, All Analytics"愿景的迈进。
Release note:https://docs.mirrorship.cn/zh/releasenotes/release-3.3/
下载:https://www.mirrorship.cn/zh-CN/download/starrocks
直播回放:https://www.bilibili.com/video/BV1F7421d72D/
关于 StarRocks
StarRocks 全球开源社区也正飞速成长。目前,StarRocks 的 GitHub star 数已达 8200,吸引了超过 350 位贡献者和数十家国内外行业头部企业参与共建,用户社区也有过万人的规模。凭借其卓越的表现,StarRocks 荣获了全球著名科技媒体 InfoWorld 颁发的 2023 BOSSIE Award 最佳开源软件奖项。