HBase概念学习(五)Java API之计数器

本文介绍了HBase中的计数器概念,它用于解决资源竞争导致的数据不一致问题。计数器通过读取并修改实现原子性操作,避免了锁的使用。文章详细展示了如何使用Java API进行计数器的初始化、增加和获取操作,包括创建、增加特定值以及批量操作。同时,指出了在编码和解码过程中需要注意的细节。
摘要由CSDN通过智能技术生成

本文为阅读《Hbase权威指南》后笔记。


1、计数器简介

之前在介绍Put和Delete的时候说道过检查并修改(Check and modify),计数器类似,也是为了防止多个客户端的资源竞争导致不一致。

如果没有计数器,用户需要针对一行加锁,读取一行的值,然后再加上特定的值,然后再写回并释放锁,尤其是当客户端进程崩溃之后,尚未释放的锁需要等待超时恢复,这样在一个高负载的系统中会引起灾难性后果。

计数器就是读取并修改(Read and modify),保证一次客户端操作的原子性。


下面是一个创建一列,并作为计数器进行累加的例子:



关于计数器的初始化:

用户不用初始化计数器,第一次使用的时候会被自动设置为0。

可以看到增加计数器使用incr命令(可以增加任意值),获取计数器用get_counter命令。

编写Java程序的时候你可以用Put直接给一个计数器赋值,但是你必须使用Bytes.toBytes(long)方法来给要设定的值进行编码,否则会得到意想不到的结果。同样你可以使用Get直接来获取计数器的值,但是你必须使用Bytes.toLong()来进行解码。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值