中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何正確的使用redisson分布式鎖

發布時間:2021-03-18 15:06:36 來源:億速云 閱讀:357 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關如何正確的使用redisson分布式鎖,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

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接口

如何正確的使用redisson分布式鎖

可以無縫對接使用Lock的業務場景,實現設計和傳遞

上述就是小編為大家分享的如何正確的使用redisson分布式鎖了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

凤阳县| 那坡县| 湘潭市| 甘孜县| 哈密市| 乐东| 巨野县| 宣化县| 永德县| 洛扎县| 巴彦淖尔市| 千阳县| 罗甸县| 瓦房店市| 蒲城县| 崇州市| 读书| 临高县| 苗栗市| 贵港市| 永昌县| 同心县| 林州市| 武冈市| 永顺县| 赤壁市| 平远县| 清新县| 云南省| 三门峡市| 云浮市| 攀枝花市| 贞丰县| 潍坊市| 晋城| 横山县| 永安市| 历史| 龙泉市| 汝阳县| 宣武区|