automatic_Hudi Cleaning操作说明
创始人
2024-10-15 13:07:44

Automatic Hudi Cleaning操作说明

automatic_Hudi Cleaning操作说明(图片来源网络,侵删)

自动Hudi清理是Apache Hudi的一个功能,用于自动删除旧的、不再需要的数据集版本,这种清理基于配置的策略,可以定期或在数据写入时执行。

1. 配置Hudi清理策略

要配置Hudi清理策略,您需要在Hudi表的Spark SQL创建语句中指定HudiTableSink选项,以下是一个示例:

 CREATE TABLE hudi_table (   ... ) USING org.apache.hudi.spark.HoodieSparkSqlQueryableDataSource OPTIONS (   'hoodie.data.publisher'='org.apache.hudi.spark.datasource.write.DataWriterFactory',   'hoodie.cleaner.commits.retained.time'='1d',   'hoodie.cleaner.min.commits'='5',   'hoodie.cleaner.enable'='true',   'hoodie.cleaner.schedule'='10 mins',   'hoodie.cleaner.policy'='COMPACTION' ); 

在这个例子中,我们配置了以下策略:

hoodie.cleaner.commits.retained.time: 保留最近1天的所有提交(即不会删除这些提交)。

hoodie.cleaner.min.commits: 至少保留5个提交,即使它们的时间戳比hoodie.cleaner.commits.retained.time更老。

hoodie.cleaner.enable: 启用自动清理。

hoodie.cleaner.schedule: 每10分钟进行一次清理。

hoodie.cleaner.policy: 使用COMPACTION策略进行清理。

2. 启动Hudi清理

一旦配置了清理策略,Hudi将在后台自动执行清理任务,如果您想手动触发清理,可以使用以下命令:

 CALL system.hudi_clean('hudi_table'); 

这将立即执行清理操作,而不是等待下一个计划的清理周期。

3. 监控和调试Hudi清理

要监控和调试Hudi清理,您可以查看Hudi表的提交历史和清理历史,以下是一些有用的查询:

查看所有提交:

 SELECT * FROM hudi_table.hoodie_commits; 

查看所有清理:

 SELECT * FROM hudi_table.hoodie_cleans; 

查看当前保留的提交:

 SELECT * FROM hudi_table.hoodie_retained_commits; 

通过这些查询,您可以了解Hudi清理是否按预期工作,以及是否需要调整清理策略。

相关内容

热门资讯

中国移动申请网络安全态势预测方... 国家知识产权局信息显示,中国移动通信集团辽宁有限公司、中国移动通信集团有限公司申请一项名为“网络安全...
济南历下两名少年站上国际科创舞... 近日,第十二届中国(上海)国际技术进出口交易会青少年发明创意展收官。这场汇聚全球22个国家、全国24...
布米普特拉北京投资基金管理有限... 美国FERC日前一致通过一项指令,要求美国六大区域电网运营商为数据中心等大型用电户建立快速接入输电系...
数据要素筑基,人工智能应用加快... 当前,人工智能加快融入经济社会发展各领域,深刻改变着生产与生活方式。在业内看来,模型能力提升只是基础...
接连两位大咖出走,谷歌到底出了... 不到一个礼拜,接连两位重量级员工都离开了谷歌。 前有Google DeepMind工程副总裁诺姆·沙...