redis中incr、incrby、decr、decrby属于string数据结构,它们是原子性递增或递减操做。redis
设置incr:key和decr:key观察用法和执行结果数据结构
1.首次观察incr:key的值,能够看到没有结果并发
127.0.0.1:6381> GET incr:key 127.0.0.1:6381>
2.对incr:key执行incr命令,能够看到redis返回了递增后的结果1。incr命令会返回递增后的结果ide
127.0.0.1:6381> incr incr:key 1 127.0.0.1:6381>
3.对incr:key执行incrby命令,能看到redis返回了递增后的结果5。incrby命令会返回递增后的结果网站
127.0.0.1:6381> incrby incr:key 4 5 127.0.0.1:6381>
4.对incr:key执行incrby命令,此次传入一个负数,能观察到redis返回了递减后的结果2spa
127.0.0.1:6381> incrby incr:key -3 2 127.0.0.1:6381>
5.对incr:key执行incrby命令,一样传入负数, 能够观察到incr:key通过递减后结果变成了负数线程
127.0.0.1:6381> incrby incr:key -4 -2 127.0.0.1:6381>
6.首次观察decr:key,没有任何结果接口
127.0.0.1:6381> GET decr:key 127.0.0.1:6381>
7.对decr:key执行decr命令,能够看到redis返回了递减后的结果ip
127.0.0.1:6381> decr decr:key -1 127.0.0.1:6381>
8.对decr:key执行decrby命令,能够看到redis返回了递减后的结果,这里的值输入的是4而不是-4get
127.0.0.1:6381> decrby decr:key 4 -5 127.0.0.1:6381>
9.对decr:key执行decrby命令,此次输入一个负数,观察一下结果
127.0.0.1:6381> decrby decr:key -1 -4 127.0.0.1:6381>
作一个实验,并发100个线程对同一个key作操做,其中50个执行incr命令,另外50个执行decr命令,观察一下结果
/** * 并发100个线程,50个线程作decr命令,另外50个线程作incr命令 * * @author tianshu on 16/10/31 上午10:52. */ public class MultipleDecrIncr { /** decr线程数量 */ private static final int DECR_THREAD_COUNT = 50; /** incr线程数量 */ private static final int INCR_THREAD_COUNT = 50; private static CountDownLatch begin = new CountDownLatch(DECR_THREAD_COUNT + INCR_THREAD_COUNT); private static CountDownLatch finish = new CountDownLatch(DECR_THREAD_COUNT + INCR_THREAD_COUNT); static final String KEY = "string:decr:incr"; public static void main(String[] args) throws InterruptedException { for(int i = 0; i < DECR_THREAD_COUNT; ++i) { new DecrThread().start(); begin.countDown(); } for(int i = 0; i < INCR_THREAD_COUNT; ++i) { new IncrThread().start(); begin.countDown(); } finish.await(); JedisConnect jedisConnect = JedisConnect.getJedisConnect(); Jedis jedis = jedisConnect.getJedis(); String value = jedis.get(KEY); System.out.println(value); jedisConnect.releaseJedis(jedis); } /** * decr命令线程 */ static class DecrThread extends Thread { @Override public void run() { try { begin.await(); } catch (InterruptedException e) { e.printStackTrace(); } JedisConnect jedisConnect = JedisConnect.getJedisConnect(); Jedis jedis = jedisConnect.getJedis(); jedis.decr(KEY); jedisConnect.releaseJedis(jedis); finish.countDown(); } } /** * incr命令线程 */ static class IncrThread extends Thread { @Override public void run() { try { begin.await(); } catch (InterruptedException e) { e.printStackTrace(); } JedisConnect jedisConnect = JedisConnect.getJedisConnect(); Jedis jedis = jedisConnect.getJedis(); jedis.incr(KEY); jedisConnect.releaseJedis(jedis); finish.countDown(); } } }
我的以为这类命令通常会应用到计数器场景