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. 读写锁
相关推荐
幼稚园的山代王26 分钟前
RabbitMQ 4.1.1初体验
分布式·rabbitmq·ruby
百锦再29 分钟前
RabbitMQ用法的6种核心模式全面解析
分布式·rabbitmq·路由·消息·通道·交换机·代理
一路向北North38 分钟前
RabbitMQ简单消息监听和确认
分布式·rabbitmq·ruby
君爱学习1 小时前
RocketMQ延迟消息是如何实现的?
后端
Falling421 小时前
使用 CNB 构建并部署maven项目
后端
程序员小假1 小时前
我们来讲一讲 ConcurrentHashMap
后端
爱上语文1 小时前
Redis基础(5):Redis的Java客户端
java·开发语言·数据库·redis·后端
萧曵 丶2 小时前
Rust 中的返回类型
开发语言·后端·rust
高兴达3 小时前
Spring boot入门工程
java·spring boot·后端