news 2026/2/26 15:29:07

Hudi 客户端实现分析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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 客户端

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

特点:

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

HoodieJavaWriteClient - Java 客户端

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

特点:

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

关键技术

索引查找

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

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

数据分区

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

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

提交管理

客户端管理提交过程:

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

关键对象说明

类关系图

关键操作时序图

代码示例

Spark 客户端使用

HoodieSparkEngineContextcontext=newHoodieSparkEngineContext(jsc);HoodieWriteConfigconfig=HoodieWriteConfig.newBuilder().withPath(basePath).build();SparkRDDWriteClientclient=newSparkRDDWriteClient(context,config);StringinstantTime=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. 提交管理保证数据一致性

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/22 11:52:15

智能体(Agent)何时能可靠完成复杂任务?

智能体&#xff08;Agent&#xff09;可靠完成复杂任务的时间线已随技术突破逐渐清晰&#xff0c;行业头部机构与专家给出了明确预判&#xff1a;短期1-3年可实现结构化场景稳定落地&#xff0c;中期5年内突破跨领域长时程任务能力&#xff0c;长期需依托底层技术迭代实现全场景…

作者头像 李华
网站建设 2026/2/24 3:00:09

Vue3 系列教程(二) 创建第一个 Vue 应用

前言 第1课已完成Vue3开发环境搭建与项目结构认知&#xff0c;本课将聚焦Vue3核心应用的创建流程&#xff0c;掌握createApp函数与mount方法的使用逻辑&#xff0c;理解单文件组件的基础结构&#xff0c;最终实现一个可独立运行的自定义Vue3应用&#xff0c;为后续指令、响应式…

作者头像 李华
网站建设 2026/2/23 5:12:04

如何让AI写的文章摆脱“AI味”

让AI写的文章摆脱“AI味”&#xff0c;核心在于用“人”的真实表达、细节和逻辑&#xff0c;去覆盖AI的模板化输出。本文梳理了一套从思路到实操的完整方法。 &#x1f3ad; 转变写作视角 尝试为AI设定一个更具体的“角色”&#xff0c;而不要让它以默认的、中立的“助手”身份…

作者头像 李华
网站建设 2026/2/25 8:02:49

先识别、再分类、后防护!工业资产安全运营的核心逻辑与实操方案

一、触目惊心的漏洞&#xff1a;90% 的安全事故源于 “不认识” 自己的资产“某汽车零部件厂遭遇勒索病毒&#xff0c;却发现 30 台未登记的老旧 PLC 设备成为攻击入口”“智能园区网络攻击事件中&#xff0c;运维人员竟不清楚被入侵的是哪台边缘计算网关”…… 工业数字化进程…

作者头像 李华