欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

redisson分布式锁的用法大全

时间:2021-10-12 09:41:47|栏目:JAVA代码|点击:

Redisson是Redis官方推荐的Java版的Redis客户端。它提供的功能非常多,此处我们只用它的分布式锁功能。

以springboot整合Redisson项目为例

添加springboot maven依赖

<dependency>
	<groupId>org.redisson</groupId>
  <artifactId>redisson-spring-boot-starter</artifactId>
  <version>3.15.1</version>
</dependency>

配置 redisson就不细讲了,咱们这边用默认配置,什么都不用配
编写测试代码

package com.miyou;

import org.junit.jupiter.api.Test;
import org.redisson.api.RedissonClient;
import org.springframework.beans.factory.annotation.Autowired;

import java.util.concurrent.locks.Lock;

public class DefaultTest extends UserRightsApplicationTests {


  @Autowired
  private RedissonClient redissonClient;

  @Test
  public void testLock() throws InterruptedException {
    Lock lock = redissonClient.getLock("test lock");
    lock.lock();
    System.out.println("锁获取成功");
    new Thread(()->{
      Lock rLock2 = redissonClient.getLock("test lock");
      rLock2.lock();
      System.out.println("线程2获取锁成功!");
      rLock2.unlock();
    }).start();
    Thread.sleep(20000);
    System.out.println("主线程释放锁");
    lock.unlock();
    Thread.sleep(1200000);
  }
}

默认情况下redisson分布式锁的超时时间为30秒,在锁即将超时的情况下redisson会检查拿到锁的线程id是否存活,如果线程存活redisson会对超时时间进行续期

redissonClient.getLock方法返回的接口类型为
org.redisson.api.RLock
查看源码,可以看到RLock继承了java.util.concurrent.locks.Lock接口

在这里插入图片描述

可以无缝对接使用Lock的业务场景,实现设计和传递

上一篇:idea常用习惯操作设置方法图解

栏    目:JAVA代码

下一篇:分析JAVA中几种常用的RPC框架

本文标题:redisson分布式锁的用法大全

本文地址:http://www.codeinn.net/misctech/179632.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有