redis的计数器应用
唯一计数是网站系统中十分常见的一个功能特性,例如网站需要统计每天访问的人数 unique visitor (也就是 UV)。计数问题很常见,但解决起来可能十分复杂:一是需要计数的量可能很大,比如大型的站点每天有数百万的人访问,数据量相当大;二是如果通过数据库表来存数据,比如记录一篇文章的访问次数,当有新的访问到来时,先要去数据库中查询这篇文章的访问量,然后加1,最后重新写入数据库,在这个过程中,如果有并发就可能导致计数错误,所以,更新文章访问量的代码都是需要加锁的,以防止同时修改,这样比较麻烦且性能很低。
Redis的所有操作都是原子性的。因此不会出现并发时导致计数错误。
INCR命令用于由一个递增key的整数值。如果该key不存在,它被设置为0执行操作之前。如果key包含了错误类型的值或包含不能被表示为整数,字符串,则返回错误。该操作被限制为64位带符号整数。
public class TestRedisIncrby {
public static void main (String args[]){
Set sentinels = new HashSet();
sentinels.add(new HostAndPort("127.0.0.1", Integer.parseInt("99999")).toString());
JedisSentinelPool jedisSentinelPool = new Je