redis分布式锁超时时间-redis分布式锁和延时锁(1-12-82)

更新时间:2024-11-30 分类:Redis 浏览量:2

Redis本文目录一览:

  • 1、Redis的主要功能?
  • 2、Redis的Setnx命令实现分布式锁
  • 3、如何使用redis实现分布式锁功能?
  • 4、redis分布式锁可能出现的问题

Redis的主要功能?

1、redis是一个单线程的NoSQL数据库,主要用来做数据缓存,一般大型网站的应用和数据库之间的那一层就是Redis。

2、Redis简介Redis是一个高性能的key-value数据库。Redis 与其他 key - value 缓存产品有以下三个特点:- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。

3、redis叫做远程字典服务,是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)和zset(有序集合)。

4、Redis支持发布订阅模式,可以用于实现实时消息推送、事件通知等场景。发布者将消息发布到特定的频道,订阅者可以订阅感兴趣的频道并接收消息,实现消息的实时分发。

Redis的Setnx命令实现分布式锁

1、可以在再次获取锁时,如果锁被占用就get值,判断值是否是当前线程存的随机值,如果是则再次执行 set 命令重新上锁;当然为了保证原子性这些操作都要用 lua 脚本来执行。

2、使用redis实现并发锁,主要是靠两个redis的命令:setnx和getset。那我们的设计思路就是:上面的代码使用了一个RedisService的类,里面主要是简单封装了一下redis的操作,你可以替换为自己的service。

3、在8版本之后,redis为了解决这个问题,提供了官方版的解法,就是命令:set key value nx expireTimeNum ex,将上述两个命令合并成了一个命令。

4、SETNX不同:SETNX(SETifNoteXists),该命令在key不存在时设置key的值,如果key存在,不做任何操作。Redishash数据结构可以存储多个键值对,所以我们可以使用Redishash实现分布式锁。

如何使用redis实现分布式锁功能?

可以尽量把锁自动过期的时间设的冗余一些。但也不能彻底解决。可以在删除锁的时候先get值,判断值是否是当前线程存的随机值,只有相同才执行删锁的操作;当然也要使用 lua 脚本执行来保证原子性。

使用分布式锁要满足的几个条件:系统是一个分布式系统(关键是分布式,单机的可以使用ReentrantLock或者synchronized代码块来实现)共享资源(各个系统访问同一个资源,资源的载体可能是传统关系型数据库或者NoSQL)。

原理很简单,set 一个 锁-key,如果成功则说明加锁成功,反之则失败。

使用redis实现并发锁,主要是靠两个redis的命令:setnx和getset。那我们的设计思路就是:上面的代码使用了一个RedisService的类,里面主要是简单封装了一下redis的操作,你可以替换为自己的service。

此时就需要使用分布式锁了。简而言之,分布式锁就是用来控制同一时刻,只有一个线程可以访问被保护的资源。可以使用 SETNX key value 命令实现互斥的特性。

我们今天就来实现用 Redis 来实现分布式锁,并且要学会怎么使用。准备使用 Jedis 的 jar 包,在项目中导入 jar 包。

redis分布式锁可能出现的问题

锁的释放问题:多个客户端竞争同一把锁时,会出现一个客户端释放了锁,但别的客户端并没有释放的情况。这会导致别的客户端无法获取到锁,从而无法继续执行后续的操作。

Redis 分布式锁不能解决超时的问题,分布式锁有一个超时时间,程序的执行如果超出了锁的超时时间就会出现问题。

问题-1 如果setnx执行成功,但是在expire执行的时候redis节点宕机了,在这种情况下,锁不会被释放,导致死锁。

释放锁的时候,只需要删除 del key 这个 key 就行了。

肯定是会占用一部分资源的,需要根据项目情况来确定是否使用,代码看注释部分差异。redisson分布式锁的使用参考上一篇博文。

这时系统在业务语义上一定会出现问题,导致各种脏数据的产生。