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对象;
value是与服务端check的预期值,只有服务器端对应rowkey的数据与你预期的值相同时,你的put操作才能被提交的服务端。