我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Redis分布式锁如何设置超时时间

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Redis分布式锁如何设置超时时间

Redis分布式锁设置超时时间

Redis分布式锁主要依靠Redis服务来完成,我们的应用程序其实是Redis节点的客户端,一旦客户端没有释放锁,服务端就会一直持有这个锁,其他进程中的线程就无法获取到这把锁,于是就会发生锁死的情况。

所以我们在使用Redis分布式锁的时候,务必要设置锁的过期时间。

主要基于下面两点:

网络抖动

客户端A中的一个线程获取到了锁,然后执行finally中的释放锁的代码时,这时候网络出问题了,导致客户端A没有成功释放锁。此时对于redis服务端来说,它会一直把锁给客户端A,这样的话其他客户端自然也就不能获取到这个锁。

如果是设置了过期时间的话,即使客户端和服务端的网络不通了,服务端依然在进行时间的计算,时间到了直接把锁释放掉,等网络通了,不影响其他客户端获取锁。

Redis宕机

客户端A获取到了锁,Redis服务器突然宕机,锁没有释放。等到Redis再次恢复的时候,Redis服务端还会把锁给到客户端A,这样也会发生锁死的情况。

如果是设置了过期时间的话,服务器恢复后就会继续倒计时,时间到了服务器自动把锁释放,其他客户端也就可以尝试去获取锁了。

Redis分布式锁的超时问题

Redis的分布式锁并不能解决超时问题,如果在加锁和释放锁之间的逻辑执行得太长,以至于超出了锁的超时限制,就会出现问题,因为这时候第一个线程持有的锁过期了,临界区的逻辑还没有执行完,而同时第二个线程就提前持有了这把锁,导致临界区代码不能得到严格串行执行。

为了避免这个问题,分布式锁不要用于较长时间的任务,如果真的偶尔出现了问题,造成的数据小错乱,可能需要人工介入解决。

有一个稍微安全一点的方案,是将set指令的value参数设置为一个随机数,释放锁时先匹配随机数是否一致,然后在删除key,这是为了确保当前线程占有的锁不会被其他线程释放,除非这个锁是自动超时,但是匹配value,和删除ke y不是一个原子操作,所以只是相对安全。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Redis分布式锁如何设置超时时间

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Redis分布式锁如何设置超时时间

目录Redis分布式锁设置超时时间网络抖动Redis宕机Redis分布式锁的超javascript时问题Redis分布式锁设置超时时间Redis分布式锁主要依靠Redis服务来完成,我们的应用程序其实是Redis节点的客户端,一旦客户端没
2022-11-18

Redis的setNX分布式锁超时时间失效 -1问题及解决

目录Redis setNX分布式锁超时时间失效 -1使用SETNX加锁使用 RedisTemplate 操作Redhttp://www.cppcns.comis解决死锁Redis分布式锁,超时问题的处理分布式可能会出现的超时问题总结Redi
2023-01-09

Redis的setNX分布式锁超时时间失效-1问题及解决

这篇文章主要介绍了Redis的setNX分布式锁超时时间失效-1问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-09

redis怎么设置hash超时时间

Redis中的hash类型是没有超时时间的,但是可以通过设置hash中每个field的值为一个带有超时时间的字符串或者其他数据类型来实现类似的效果。具体实现的步骤如下:1. 使用HSET命令将field和value添加到hash中,valu
2023-09-01

Java如何设置session超时时间

小编给大家分享一下Java如何设置session超时时间,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在一般系统登录后,都会设置一个当前session失效的时间,
2023-06-06

redis并发锁时间怎么设置

在 Redis 中实现并发锁,可以使用 SETNX(SET if Not eXists)指令。该指令会在键不存在时设置键的值,如果键已经存在,则不执行任何操作。在并发锁的场景中,可以将锁的持有者设置为一个唯一的标识,比如使用线程或进程的 I
2023-08-30

oracle事务超时时间如何设置

在Oracle数据库中设置事务超时时间可以通过设置参数SQLNET.INBOUND_CONNECT_TIMEOUT来实现。这个参数定义了客户端连接到Oracle服务器的超时时间,单位为秒。默认值为60秒,可以根据具体情况进行调整。可以通过
oracle事务超时时间如何设置
2024-04-09

Oracle空闲超时时间如何设置

本文小编为大家详细介绍“Oracle空闲超时时间如何设置”,内容详细,步骤清晰,细节处理妥当,希望这篇“Oracle空闲超时时间如何设置”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Oracle空闲超时时间设置远
2023-07-06

php如何设置会话超时时间

这篇文章主要介绍“php如何设置会话超时时间”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“php如何设置会话超时时间”文章能帮助大家解决问题。什么是PHP会话PHP会话是一个用于在服务端存储数据的机
2023-07-06

PHP连接超时时间如何设置

本篇内容主要讲解“PHP连接超时时间如何设置”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PHP连接超时时间如何设置”吧!连接超时时间是指当我们进行网络请求时,如果服务器无法响应请求,那么客户端
2023-07-05

php如何设置超时等待时间

本文小编为大家详细介绍“php如何设置超时等待时间”,内容详细,步骤清晰,细节处理妥当,希望这篇“php如何设置超时等待时间”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。在使用 PHP 进行开发时,有时需要执行耗
2023-07-05

redis如何设置存储时间设置

在Redis中,可以使用EXPIRE命令来设置键的过期时间。该命令接受两个参数,第一个参数为键名,第二个参数为过期时间,单位为秒。例如,以下命令将键mykey的过期时间设置为3600秒(1小时):```EXPIRE mykey 3600``
2023-09-11

Mysql中的超时时间设置方式

这篇文章详细阐述了MySQL中超时时间设置方式,包括连接超时、查询超时和数据发送/接收超时。通过正确设置这些超时值,可以防止资源浪费并提高数据库性能。最佳实践包括合理设置连接超时、根据查询复杂性优化查询超时,并针对不同网络负载调整数据发送/接收超时。此外,文章提供了故障排除建议和说明了会话级和全局级超时设置以及其他注意事项。
Mysql中的超时时间设置方式
2024-04-02

Oracle空闲超时时间设置方式

目录oracle空闲超时时间设置Oracle长连接超时设置方法一方法二总结Oracle空闲超时时间设置远程连接oracle 会出现超时连接断开的问题,所以需要修改oracle配置。修改超时时间10分钟ALTER PROFILE DEF
2023-04-12

编程热搜

目录