Hbase中checkAndPut操作

HBase中的Insert和Update操作无明显差别,可能导致数据不一致。为了解决这个问题,文章介绍了HBase的compare-and-set(CAS)操作,特别是checkAndPut方法,用于在写入数据前验证条件,确保数据一致性。该方法允许客户端在put操作前检查预期值,只有匹配时才执行。此外,内容中还提到并发情况下可能出现的中间态问题,并鼓励读者学习人工智能。
摘要由CSDN通过智能技术生成
                       

Hbase中Insert和Update操作没有明显的差别。
如果误操作,是否可以恢复数据?
方法:通过timeStamp找回数据。

但是,如果我们可以在源头实现,是否更好呢?
问题:
客户端1:
 row1:  family 1 : qulifier1(1) qulifier2(2)
客户端2:
 row1:  family 1 : qulifier1(-1) qulifier2(-2)

我们想要的结果是:要么是客户端2的结果,要么是客户端1的结果。
如果在高并发的情况下,会出现中间态,qulifier(1) qulifier(-2) 或者 qulifier(-1) qulifier(2)
HBase中有个CAS(compare-and-set)操作用来解决这个问题(数据一致性),简单的说CAS操作可以让你在put数据之前先经过某些条件的验证,只有满足条件的put才会入库。

API接口为:
checkAndPut(byte.md row, byte.md family, byte.md qualifier, byte.md value, Put put)
其中,put方法的最后一个参数是你需要录入的数据的put对象&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值