分布式锁机制

分布式锁

Redisson实现分布式锁

Github:https://github.com/redisson/redisson
官网:Redisson: Easy Redis Java client with features of In-Memory Data Grid

实现步骤

  1. maven引入,进入redisson的github往下拉,readme中有步骤
点击查看代码
<dependency>
   <groupId>org.redisson</groupId>
   <artifactId>redisson</artifactId>
   <version>3.27.2</version>
</dependency> 
  1. 自己编写 Redisson 的配置,创建 RedissonClient
  • 因为spring-boot-starter 整合的 Redisson迭代较快,不推荐使用
  • 新建Config配置,使用注解读取application的redis配置信息
  • 创建 Redisson 实例,返回 Redisson 客户端实例
  1. 测试Redisson

Redisson中的数据结构都继承与Java的数据结构,比如Redisson其中的RList和RMap继承的接口为List和ConcurrentMap

点击查看代码
//引入Redisson客户端
@Resource
private RedissonClient redissonClient;

4.定时任务+锁

  • getLock()获取Redisson的锁对象,需要指定锁的名称
  • tryLock()尝试获取分布式锁,获取成功返回true
    有两个参数
    waitTime:等待锁时间,置0意味着只尝试一次
    leaveTime:锁过期时间,时间一到就释放锁(这里有个问题当执行时间超过锁过期的时间,即锁在程序运行中释放了,通俗易懂点就我在拉屎,拉一半门打开了,怎么解决)
  • unLock:()释放锁,一般设置在finlly代码块中,保证代码执行完后释放锁
点击查看代码
        RLock lock = redissonClient.getLock("lcok");

        try {
            if (lock.tryLock(0,30000L,TimeUnit.MILLISECONDS)){
                System.out.printf("getLock: " + Thread.currentThread().getId());
            }
        } catch (InterruptedException e) {
            e.printStackTrace();
        } finally {
            // 只能释放自己的锁
            if (lock.isHeldByCurrentThread()) {
                System.out.println("unLock: " + Thread.currentThread().getId());
                lock.unlock();
            }
        }
posted @   foxcyg  阅读(15)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
· 提示词工程——AI应用必不可少的技术
点击右上角即可分享
微信分享提示