使用Redisson工具实现分布式锁

上一篇 << 下一篇 >>>Redis集群模式之主从复制原理及存在的缺陷


1、引入redisson依赖包


    org.redisson
    redisson-spring-boot-starter
    3.11.0

2、增加配置文件

redisson.singleServerConfig.address=127.0.0.1:6379

3、Redisson实现分布式锁

@GetMapping("/seckill")
public synchronized String seckill() throws InterruptedException {
    RLock seckillLock = redissonClient.getLock("seckillLock");
    try {
        seckillLock.tryLock(3, TimeUnit.SECONDS);
        String stock = stringRedisTemplate.opsForValue().get("Stock");
        int nStock = Integer.valueOf(stock) - 1;
        if (nStock > 0) {
            //成功秒杀到
            nStock = Integer.valueOf(stock) - 1;
            stringRedisTemplate.opsForValue().set("Stock", nStock + "");
            System.out.println("成功秒杀商品了,还剩余商品:" + nStock);
            return "恭喜您,下单成功";
        }
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        seckillLock.unlock();
    }
    System.out.println("商品库存不足");
    return "当前库存不足";
}

4、getLock和tryLock的区别

tryLock(long time, TimeUnit unit)方法和tryLock()方法是类似的,只不过区别在于这个方法在拿不到锁时会等待一定的时间,在时间期限之内如果还拿不到锁,就返回false。如果一开始拿到锁或者在等待期间内拿到了锁,则返回true。


推荐阅读:
<<<分布式缓存与本地缓存的区别
<< << << << << << << << << << << << << << << << << << << << << << << << << << <<<阿里云的Canal框架实现Redis与Mysql同步原理及代码示例
<<<阿里云的Canal框架配置
<< << <<

你可能感兴趣的:(使用Redisson工具实现分布式锁)