Redisson 实现分布式锁实战指南

Redisson 实现分布式锁

回答

  • 在使用 SETNX 实现的分布式锁中,因为,存在锁无法续期,导致并发冲突的问题。所以,在真实的生产环境中用的并不是很多。

  • 实际工作中,用的比较多的是基于 Redisson 实现分布式锁

    Redisson 是一个基于 Redis 的 Java 客户端,它提供了丰富的功能,包括分布式锁的支持。

    redlisson.org

    关于 Redisson 实现分布式锁可以参考:

    github.com/redisson/re...

  • 为了避免锁超时,Redisson 中引入了看门狗的机制。

    他可以帮助我们在 Redisson 实例被关闭前,不断的延长锁的有效期。

    默认情况下,看门狗的检查锁的超时时间是30秒钟

    也可以通过修改 Config.lockWatchdogTimeout 来另行指定。

如何实现一个可重入的分布式锁
  1. 引入依赖
  1. 定义一个 Redisson 客户端
  1. 加锁/解锁 操作
  1. 设置超时时间
  1. 公平锁

参考:Java 并发#公平锁 vs 非公平锁

  1. 联锁
  1. 读写锁
相关推荐
杨DaB16 分钟前
【SpringMVC】拦截器,实现小型登录验证
java·开发语言·后端·servlet·mvc
努力搬砖ll1 小时前
分布式弹幕系统设计
分布式
九伯都5 小时前
rabbitmq的安装和使用-windows版本
windows·分布式·rabbitmq
努力的小雨7 小时前
还在为调试提示词头疼?一个案例教你轻松上手!
后端
魔都吴所谓7 小时前
【go】语言的匿名变量如何定义与使用
开发语言·后端·golang
陈佬昔没带相机8 小时前
围观前后端对接的 TypeScript 最佳实践,我们缺什么?
前端·后端·api
你我约定有三8 小时前
分布式微服务--万字详解 微服务的各种负载均衡全场景以注意点
java·开发语言·windows·分布式·微服务·架构·负载均衡
Livingbody9 小时前
大模型微调数据集加载和分析
后端
Livingbody9 小时前
第一次免费使用A800显卡80GB显存微调Ernie大模型
后端
哈哈很哈哈10 小时前
Hadoop JMX 配置的完整文档
大数据·hadoop·分布式