欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redisson分布式鎖解鎖異常問題

 更新時間:2024年12月24日 08:43:08   作者:知知之之  
文章主要描述了在使用Redisson進行分布式鎖操作時,遇到的`IllegalMonitorStateException`異常,通過分析報錯信息,作者發(fā)現(xiàn)了問題的根源在于線程嘗試解鎖但未按順序執(zhí)行,作者提出了兩種解決方案:在解鎖前增加判斷,確保線程已獲得鎖

問題現(xiàn)象

程序中的redission執(zhí)行unlock()報錯如下:

java.lang.IllegalMonitorStateException: attempt to unlock lock, not locked by current thread by node id:

從報錯信息可知:嘗試解鎖,而不是由當(dāng)前線程按節(jié)點 ID 鎖定

問題復(fù)現(xiàn)

//獲取鎖對象
RLock lock = redissonClient.getLock(key);

try{
   //獲取鎖
   boolean tryLock = lock.tryLock(5, TimeUnit.SECONDS);
   if (!tryLock) {
   //拋出業(yè)務(wù)異常
   }
}catch(){
    //捕獲異常
}finally{
    //解鎖
    lock.unlock();
}

排查過程

如上代碼,線程無論是否有獲取鎖,都是需要去執(zhí)行解鎖方法,當(dāng)線程沒有獲得鎖,執(zhí)行unlock()就會報

java.lang.IllegalMonitorStateException: attempt to unlock lock, not locked by current thread by node id:錯誤

解決方案

1、在解鎖時增加判斷

//判斷要解鎖的key是否已被鎖定;判斷要解鎖的key是否被當(dāng)前線程持有
if (lock.isLocked() && lock.isHeldByCurrentThread()) {
    lock.unlock();
}

2、優(yōu)化代碼

在執(zhí)行unlock()確保線程已經(jīng)獲得鎖

//獲取鎖對象
RLock lock = redissonClient.getLock(key);
boolean tryLock;
try {
    tryLock = lock.tryLock(5, TimeUnit.SECONDS);
} catch (InterruptedException e) {
    throw new Exception("獲取分布式鎖失敗,請稍后再試");
}

if (!tryLock) {
    throw new Exception("請稍后再試");
}

try{
   //拋出業(yè)務(wù)異常
}catch(){
    //捕獲異常
}finally{
    //解鎖
    lock.unlock();
}

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Redis緩存降級的四種策略

    Redis緩存降級的四種策略

    在高并發(fā)系統(tǒng)架構(gòu)中,Redis作為核心緩存組件扮演著至關(guān)重要的角色,它不僅能夠顯著提升系統(tǒng)響應(yīng)速度,還能有效減輕數(shù)據(jù)庫壓力,然而,當(dāng)Redis服務(wù)出現(xiàn)故障、性能下降或連接超時時,如果沒有適當(dāng)?shù)慕导墮C制,可能導(dǎo)致系統(tǒng)雪崩,所以本文給大家介紹了Redis緩存降級的四種策略
    2025-04-04
  • Redis Cluster 字段模糊匹配及刪除

    Redis Cluster 字段模糊匹配及刪除

    在數(shù)據(jù)庫內(nèi)我們可以通過like關(guān)鍵字、%、*或者REGEX關(guān)鍵字進行模糊匹配。而在Redis內(nèi)我們?nèi)绾芜M行模糊匹配呢?本文就來介紹一下
    2021-05-05
  • 利用Redis?lua實現(xiàn)高效讀寫鎖的代碼實例

    利用Redis?lua實現(xiàn)高效讀寫鎖的代碼實例

    這篇文章給大家介紹了如何利用Redis?lua實現(xiàn)高效的讀寫鎖,讀寫鎖的好處就是能幫助客戶讀到的數(shù)據(jù)一定是最新的,寫鎖是排他鎖,而讀鎖是一個共享鎖,需要的朋友可以參考下
    2024-01-01
  • redis不能訪問本機真實ip地址的解決方案

    redis不能訪問本機真實ip地址的解決方案

    這篇文章主要介紹了redis不能訪問本機真實ip地址的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Redis?Key使用{}原因分析

    Redis?Key使用{}原因分析

    這篇文章主要為大家介紹了Redis中Key中為什么要使用{}原因分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • redis計數(shù)器與數(shù)量控制的實現(xiàn)

    redis計數(shù)器與數(shù)量控制的實現(xiàn)

    使用Redis計數(shù)器可以輕松地解決數(shù)量控制的問題,同時還能有效地提高應(yīng)用的性能,本文主要介紹了redis計數(shù)器與數(shù)量控制的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • 淺談Redis阻塞的9種情況

    淺談Redis阻塞的9種情況

    本文主要介紹了淺談Redis阻塞的9種情況,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • redis性能優(yōu)化之生產(chǎn)中實際遇到的問題及排查總結(jié)

    redis性能優(yōu)化之生產(chǎn)中實際遇到的問題及排查總結(jié)

    這篇文章主要介紹了redis性能優(yōu)化之生產(chǎn)中實際遇到的問題及排查總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 利用Redis實現(xiàn)防止接口重復(fù)提交功能

    利用Redis實現(xiàn)防止接口重復(fù)提交功能

    大家好,本篇文章主要講的是利用Redis實現(xiàn)防止接口重復(fù)提交功能,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • Redis去重的3種不同方法匯總

    Redis去重的3種不同方法匯總

    Redis是完全開源免費的,遵守BSD協(xié)議,是一個高性能的key-value數(shù)據(jù)庫,下面這篇文章主要給大家介紹了關(guān)于Redis去重的3種不同方法,需要的朋友可以參考下
    2021-11-11

最新評論