本文为阅读《Hbase权威指南》后笔记。
1、计数器简介
之前在介绍Put和Delete的时候说道过检查并修改(Check and modify),计数器类似,也是为了防止多个客户端的资源竞争导致不一致。
如果没有计数器,用户需要针对一行加锁,读取一行的值,然后再加上特定的值,然后再写回并释放锁,尤其是当客户端进程崩溃之后,尚未释放的锁需要等待超时恢复,这样在一个高负载的系统中会引起灾难性后果。
计数器就是读取并修改(Read and modify),保证一次客户端操作的原子性。
下面是一个创建一列,并作为计数器进行累加的例子:
关于计数器的初始化:
用户不用初始化计数器,第一次使用的时候会被自动设置为0。
可以看到增加计数器使用incr命令(可以增加任意值),获取计数器用get_counter命令。
编写Java程序的时候你可以用Put直接给一个计数器赋值,但是你必须使用Bytes.toBytes(long)方法来给要设定的值进行编码,否则会得到意想不到的结果。同样你可以使用Get直接来获取计数器的值,但是你必须使用Bytes.toLong()来进行解码。