当前位置: 首页 > news >正文

Redis——》如何评估锁过期时间

推荐链接:
    总结——》【Java】
    总结——》【Mysql】
    总结——》【Redis】
    总结——》【Kafka】
    总结——》【Spring】
    总结——》【SpringBoot】
    总结——》【MyBatis、MyBatis-Plus】
    总结——》【Linux】
    总结——》【MongoDB】
    总结——》【Elasticsearch】

Redis——》如何评估锁过期时间

  • 一、锁过期的场景
  • 二、锁过期的解决方案
    • 方案1:尽量冗余过期时间
    • 方案2:加入看门狗守护线程

一、锁过期的场景

key的失效时间是10s,但是客户端C在拿到分布式锁之后,然后业务逻辑执行超过10s,那么问题来了,在客户端C释放锁之前,其实这把锁已经失效了,那么客户端A和客户端B都可以去拿锁,这样就已经失去了分布式锁的功能了!!!
image.png

二、锁过期的解决方案

方案1:尽量冗余过期时间

降低锁提前过期的概率,但这个方案并不能完美解决问题。

方案2:加入看门狗守护线程

加锁时,先设置一个预估的过期时间,然后开启一个守护线程,定时去检测这个锁的失效时间,如果锁快要过期了,操作共享资源还未完成,那么就自动对锁进行续期,重新设置过期时间。这个守护线程我们一般把它叫做看门狗线程
image.png

http://www.lryc.cn/news/149459.html

相关文章:

  • 完整开发实现公众号主动消息推送,精彩内容即刻到达
  • 获取ip(公网和内网) 前端通过高德api获取位置信息
  • linux打开端口命令是什么
  • 从《孤注一掷》出发,聊聊 SSL 证书的重要性
  • 专题:曲面的切平面、法线
  • 数据结构:排序解析
  • Revit SDK:AutoJoin 自动合并体量
  • MYSQL(索引、事务)
  • 部署问题集合(二十三)设置Docker容器内的中文字符集,解决某些情况下中文乱码的问题
  • Web AP—PC端网页特效
  • Spring线程池ThreadPoolTaskExecutor使用
  • spring mvc的执行流程
  • docker作业
  • java实现本地文件转文件流发送到前端
  • 2020ICPC南京站
  • Linux 中的 chsh 命令及示例
  • JavaScript 数组如何实现冒泡排序?
  • ZooKeeper集群环境搭建
  • 【跟小嘉学 Rust 编程】二十、进阶扩展
  • pytorch学习过程中一些基础语法
  • 判断聚类 n_clusters
  • 基于深度学习的网络异常检测方法研究
  • SSM 基于注解的整合实现
  • 工具类APP如何解决黏性差、停留短、打开率低等痛点?
  • 使用Java MVC开发高效、可扩展的Web应用
  • wandb安装方法及本地部署教程
  • stable diffusion实践操作-提示词插件安装与使用
  • 【SpringBoot】详细介绍SpringBoot中的bean
  • 【Nuxt实战】在Nuxt3项目中如何按需引入Element-plus
  • 专业制造一体化ERP系统,专注于制造工厂生产管理信息化,可定制-亿发