redis的计数器应用

                                                                           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 JedisSentinelPool("redis", sentinels);
		
		Jedis jedis = jedisSentinelPool.getResource();
		jedis.set("rediscount", "5");
	    String  count = jedis.get("rediscount");
	    System.out.println("count="+count+"hello lulu");
	    
	    jedis.incr("rediscount");
	    String  count1 = jedis.get("rediscount");
	    System.out.println("count1="+count1+"hello lulu1");
	    
	    jedis.incrBy("rediscount", 10);
	    String  count2 = jedis.get("rediscount");
	    System.out.println("count2="+count2+"hello lulu2");
	    
	    
	    

	}

}
运行结果:

count=5hello lulu
count1=6hello lulu1
count2=16hello lulu2


你可能感兴趣的:(redis)