HBase—Compaction之详解

本文详细介绍了HBase的Compaction,包括Minor和Major Compaction的定义,合并流程,触发时机,以及多种合并策略,如RatioBased、Exploring、FIFO、Tier-Based和Stripe Compaction策略。
摘要由CSDN通过智能技术生成

1.概述

  • Compaction核心功能是合并小文件,HBase的Compaction分为Minor Compaction和major Compaction两类

    • Minor Compaction选取部分小的,相邻的HFile文件进行合并

    • Major Compaction是将一个Store中的所有HFile文件合并成一个更大的HFile

2.合并流程

  • HBase启动一个独立线程从对应的Store中选取要合并的HFile
  • 从这些HFile中依次读出KeyValue,进行归并排序处理写到./tmp目录下的临时文件
  • 将临时文件移动到Store的数据目录
  • 将Compation的输入文件路径和输出文件封装成KeyValue写入HLog,并标记为Compation,强行执行sync
  • 合并成新的HFile取代之前的HFile对外提供服务
  • 删除已经被合并的HFile文件

3.触发时机

  • MemStore Flush:每次MemStore Flush都会检查当前Store的文件数量,如果达到阈值则触发Compaction,此时整个Region的所有Store都会执行Compact检查
  • 后台周期性检查:后台线程CompactionChecker定期触发检查对应的Store是否需要执行Compation,先检查Store的文件数量然后检查是否满足Major Compation条件(默认7天执行一次)
  • 手动触发

4.合并策略

  • 合并前检查
    • 排除正则执行Compation的文件以及比这些文件更新的所
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值