HBase0.94在flush操作时候的一个漏洞

基于HBase0.94版本,在高并发写操作时,运行时偶尔出现丢失数据的情况,查看了HBase的日志,出现一下信息,

WARN org.apache.hadoop.hbase.regionserver.MemStore: Snapshot called again without clearing previous. Doing nothing. Another ongoing flush or did we fail last attempt?

这个问题是HBase在flush操作时的一个bug,HBase JIRA中有对应的patch,HBASE-7671(Flushing memstore again after last failure could cause data loss)

下面对出现这个问题的原因分析一下,

我们知道HBase在memstore达到一定阈值时会进行flush操作,flush主要包括三个过程,snapshot,flush cache,commit

snapshot是对memstore中的内存对象进行快照,在快照过程中需要阻塞write操作,snapshot完成后,重置内存中的对象。

flush cache过程基于snapshot生成tmp HFile,同时在HFile中的元数据中保存seqNum,这个seqNum是基于HLog的当前region最后完成的seqNum(写数据的HLog key value 对会带上seqNum)。

commit提交flush,把storeFile加入到Store中,并清除memstore snapshot(此时判断是否需要进行compact操作)(调用Store.updateStorefiles,会对store的lock加写锁,这样其他的写数据的操作就会堵塞<读锁>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
假设我们已经有一个Hbase表,其中包含以下列族和列: - 列族:info - 列:name - 列:age - 列族:address - 列:city - 列:state 现在我们想过滤出所有年龄大于等于18岁的行。我们可以使用Hbase的SingleColumnValueFilter过滤器来实现这个操作。以下是一个Java代码示例: ```java // 创建一个连接到Hbase的配置对象 Configuration config = HBaseConfiguration.create(); config.set("hbase.zookeeper.quorum", "localhost"); config.set("hbase.zookeeper.property.clientPort", "2181"); // 创建一个Hbase表的连接对象 Connection connection = ConnectionFactory.createConnection(config); // 获取表对象 Table table = connection.getTable(TableName.valueOf("mytable")); // 创建过滤器 SingleColumnValueFilter filter = new SingleColumnValueFilter( Bytes.toBytes("info"), // 列族 Bytes.toBytes("age"), // 列 CompareOperator.GREATER_OR_EQUAL, // 操作符 Bytes.toBytes(18) // 值 ); // 创建扫描器对象 Scan scan = new Scan(); scan.setFilter(filter); // 执行扫描 ResultScanner scanner = table.getScanner(scan); // 遍历结果集并输出 for (Result result : scanner) { System.out.println(result); } // 关闭资源 scanner.close(); table.close(); connection.close(); ``` 这个示例中,我们使用SingleColumnValueFilter创建了一个过滤器,并将它应用到了一个扫描器上。然后我们遍历了结果集并输出了每一行的数据。注意,在使用完成之后,我们需要关闭资源以释放内存。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值