Redis分布式锁

        作为分布式锁实现过程中的共享存储系统,Redis 可以使用键值对来保存锁变量,在接收和处理不同客户端发送的加锁和释放锁的操作请求。        

1.setnx

        想要实现分布式锁,必须要求 Redis 有互斥的能力。可以使用 SETNX 命令, 其含义是 SET IF NOT EXIST,即如果 key 不存在,才会设置它的值,否则什么 也不做。两个客户端进程可以执行这个命令,达到互斥,就可以实现一个分布式锁.

但是,以上实现存在一个很大的问题,当客户端 1 拿到锁后,如果发生下面的场景,就会造成死锁。

1. 程序处理业务逻辑异常,没及时释放锁

2. 进程挂了,没机会释放锁 以上情况会导致已经获得锁的客户端一直占用锁,其他客户端永远无法获取到锁 

2.redission

配置

<dependency>
 <groupId>org.redisson</groupId>
 <artifactId>redisson</artifactId>
 <version>3.6.5</version>
</dependency>
 @Bean
 public Redisson getRedisson(){
     Config config = new Config();
     config.useSingleServer().setAddress("redis://127.0.0.1:6379").setDatabase(0);
     return (Redisson)Redisson.create(config);
}

案例

public String stock(){
    RLock lock = redisson.getLock("stock_lock");
    try{
        lock.lock(30,TimeUnit.SECONDS);
        //从redis中获取
        Integer stock = (Integer)redisTemplate.opsForValue().get("stock");
        if(stock>0){
           int real = stock - 1;
           redisTemplate.opsForValue.set("stock",real);
           System.out.print("扣除成功,实际库存:"+real);
        }else{
           System.out.print("扣除失败");
        }finally{
           lock.unlock();
        }
    }
    return "success";
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值