Hudi 客户端实现分析

08. Hudi 客户端实现分析

主题说明

Hudi 提供了三种客户端实现:Spark、Flink 和 Java。理解客户端实现有助于理解不同引擎下的写入机制。

客户端实现包括:

  • BaseHoodieWriteClient:客户端基类
  • SparkRDDWriteClient:Spark 客户端
  • HoodieFlinkWriteClient:Flink 客户端
  • HoodieJavaWriteClient:Java 客户端

细化内容

BaseHoodieWriteClient - 客户端基类

BaseHoodieWriteClient 是所有客户端的基类,定义了通用的写入逻辑。

主要方法:

  • startCommit():开始新的提交
  • upsert():更新或插入
  • insert():插入
  • delete():删除
  • commit():提交

核心逻辑:

  • 索引查找
  • 数据分区
  • 文件写入
  • 提交管理

SparkRDDWriteClient - Spark 客户端

SparkRDDWriteClient 是 Spark 的客户端实现,使用 JavaRDD 作为数据容器。

特点:

  • 使用 Spark 的分布式计算
  • 支持大规模数据处理
  • 自动管理 Spark 任务

HoodieFlinkWriteClient 是 Flink 的客户端实现,支持流式写入。

特点:

  • 支持流式写入
  • Checkpoint 集成
  • 状态管理

HoodieJavaWriteClient - Java 客户端

HoodieJavaWriteClient 是 Java 的客户端实现,使用 List 作为数据容器。

特点:

  • 单机处理
  • 简单易用
  • 适合小规模数据

关键技术

索引查找

所有客户端都使用索引来查找记录位置:

  • Bloom Index:布隆过滤器索引
  • Simple Index:简单索引
  • Global Index:全局索引

数据分区

客户端根据分区字段对数据进行分区:

  • 分区策略:按分区路径分区
  • 文件组分配:分配文件组
  • 写入优化:优化写入性能

提交管理

客户端管理提交过程:

  • Instant 创建:创建提交时间点
  • 元数据生成:生成提交元数据
  • Timeline 更新:更新 Timeline

关键对象说明

类关系图

关键操作时序图

代码示例

Spark 客户端使用

java 复制代码
HoodieSparkEngineContext context = new HoodieSparkEngineContext(jsc);
HoodieWriteConfig config = HoodieWriteConfig.newBuilder()
    .withPath(basePath)
    .build();

SparkRDDWriteClient client = new SparkRDDWriteClient(context, config);
String instantTime = client.startCommit();
JavaRDD<WriteStatus> writeStatuses = client.upsert(records, instantTime);
client.commit(instantTime, writeStatuses);

总结

Hudi 提供了三种客户端实现,每种都有其适用场景。核心要点:

  1. BaseHoodieWriteClient 是客户端基类
  2. SparkRDDWriteClient 适用于 Spark 环境
  3. HoodieFlinkWriteClient 适用于 Flink 流式写入
  4. HoodieJavaWriteClient 适用于 Java 单机处理
  5. 索引查找 是通用的核心逻辑
  6. 提交管理 保证数据一致性

理解客户端实现有助于在不同场景下选择合适的客户端。

相关推荐
是码龙不是码农1 分钟前
支付防重复下单|5 种幂等性设计方案(从初级到架构级)
java·架构·幂等性
曹牧2 分钟前
Spring Boot:如何在Java Controller中处理POST请求?
java·开发语言
heartbeat..2 分钟前
JVM 性能调优流程实战:从开发规范到生产应急排查
java·运维·jvm·性能优化·设计规范
喵叔哟4 分钟前
02-YOLO-v8-v9-v10工程差异对比
人工智能·yolo·机器学习
浅念-5 分钟前
C++入门(2)
开发语言·c++·经验分享·笔记·学习
WeiXiao_Hyy5 分钟前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
玄同7656 分钟前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
L、2186 分钟前
CANN 内存管理深度解析:高效利用显存,突破 AI 推理瓶颈
人工智能
聊聊科技8 分钟前
原创音乐人使用AI编曲软件制作伴奏,编曲用什么音源好听
人工智能
爱吃烤鸡翅的酸菜鱼8 分钟前
CANN ops-nn卷积算子深度解析与性能优化
人工智能·性能优化·aigc