redis分布式锁

原文:https://baijiahao.baidu.com/s?id=1623086259657780069&wfr=spider&for=pc

redis 分布式锁的实现方法,表面上看很简单。
指定一个key, 获取锁 ,查询一下redis中 这个key有没有值,没有,就设置,获取锁就成功了,
释放锁,就删除这个key

  1. 问题:并发判断redis中 都没有key, 同时去加锁,会出现覆盖问题
    解决: 使用 setnx 命令,不存在才设置,只有一个能设置锁成功
  2. 问题: 线程还未来得及释放锁,程序奔溃了,其他的都被阻塞了。
    解决: 对加入的锁,设置一个过期时间。
  3. 问题: setnx 和 expire 添加和设置过期不是原子操作,还是会出现锁无法释放
    解决: redis2.8以后新增了指令 set lock:key true ex 5 nx
    使用LUA脚本设置,是比较通用的方式
String script = "local rs=redis.call('setnx',KEYS[1],ARGV[1]);if(rs<1) then return 'F';end;redis.call('expire',KEYS[1],tonumber(ARGV[2]));return 'S';";
Jedis jedis = shardedJedis.getShard(redisKey);  
Object result = jedis.evalsha(script, keys, args);
if ("S".equals(result)) {
    return true;
}
  出处:https://www.2cto.com/kf/201809/780811.html
  1. 问题: 释放锁的时候,锁过期,被其他线程获取到锁,然后这个线程执行后释放了锁
    解决: 加锁的时候设置一个随机值,释放锁的时候,先取出来判断 这个值是否有变更,如果变更了说明锁已经被其他人占有了,没有变更,释放锁。 这个地方 判断和 释放锁,不是原子性,需要使用lua脚本 保证原子性

以上都针对的是 单机的情况。
如果 有备机切换的话,这种情况就有问题了。
那怎么办?

redis集群的分布式锁

Redisson 实现方式(红锁 RedLock)

github Redisson https://github.com/redisson/redisson

 <dependency>
   <groupId>org.redisson</groupId>
   <artifactId>redisson</artifactId>
   <version>3.9.0</version>
</dependency>  

<!-- JDK 1.6+ compatible -->
<dependency>
   <groupId>org.redisson</groupId>
   <artifactId>redisson</artifactId>
   <version>2.14.0</version>
</dependency>

RedLock 实现的算法规则

  1. 加锁时,给redis集群的 每一个master 都加锁。
  2. 加锁成功的条件:a. 超过半数的机器加锁成功,b. 总加锁时间,小于单个锁超时时间
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值