天天看點

面試官問我,Redis分布式鎖如何續期?懵了。

前言

上一篇[面試官問我,使用Dubbo有沒有遇到一些坑?我笑了。]之後,又有一位粉絲和我說在面試過程中被虐了.鑒于這位粉絲是之前肥朝的

老粉絲

,而且周一又要開啟新一輪的面試,為了回饋他長期以來的支援,是以連夜寫了本篇,希望能對他接下來的面試有所幫助.

真實案例

面試官問我,Redis分布式鎖如何續期?懵了。

Redis分布式鎖的正确姿勢

據肥朝了解,很多同學在用分布式鎖時,都是直接百度搜尋找一個Redis分布式鎖工具類就直接用了.關鍵是該工具類中還充斥着很多

System.out.println();

等語句.其實Redis分布式鎖比較正确的姿勢是采用

redisson

這個用戶端工具.具體介紹可以搜尋最大的同性交友網站

github

.

如何回答

首先如果你之前用Redis的分布式鎖的姿勢正确,并且看過相應的官方文檔的話,這個問題

So easy

.我們來看

坦白說,如果你英文棒棒哒那麼看英文文檔可能更好了解

By default lock watchdog timeout is 30 seconds and can be changed through Config.lockWatchdogTimeout setting.

但是你如果看的是中文文檔

看門狗檢查鎖的逾時時間預設是30秒

這句話肥朝從國文角度分析就是一個歧義句,他有兩個意思

1.看門狗預設30秒去檢查一次鎖的逾時時間

2.看門狗會去檢查鎖的逾時時間,鎖的時間時間預設是30秒

看到這裡,我希望大家不要黑我的國小體育老師,雖然他和國文老師是同個人.國文不行,我們可以源碼來湊!

源碼分析

我們根據官方文檔給出的例子,寫了一個最簡單的demo,例子根據上面截圖中

Ctr+C和Ctr+V

一波操作,如下

1public class DemoMain {
 2
 3    public static void main(String[] args) throws Exception {
 4        Config config = new Config();
 5        config.useSingleServer().setAddress("redis://127.0.0.1:6379");
 6
 7        RedissonClient redisson = Redisson.create(config);
 8        RLock lock = redisson.getLock("anyLock");
 9
10        lock.lock();
11        //lock.unlock();
12    }
13}
           

create

面試官問我,Redis分布式鎖如何續期?懵了。

從這裡我們知道,

internalLockLeaseTime

 和 

lockWatchdogTimeout

這兩個參數是相等的.

lockWatchdogTimeout

預設值如下

1public class Config {
 2
 3    private long lockWatchdogTimeout = 30 * 1000;
 4
 5    public long getLockWatchdogTimeout() {
 6        return lockWatchdogTimeout;
 7    }
 8
 9    //省略無關代碼
10}
           

internalLockLeaseTime

這個單詞也可以看出,這個加的分布式鎖的逾時時間預設是30秒.但是還有一個問題,那就是這個看門狗,多久來延長一次有效期呢?我們往下看

lock

面試官問我,Redis分布式鎖如何續期?懵了。

從我圖中框起來的地方我們就知道了,擷取鎖成功就會開啟一個定時任務,也就是

watchdog

,定時任務會定期檢查去續期

renewExpirationAsync(threadId)

這裡定時用的是

netty-common

包中的

HashedWheelTimer

,肥朝公衆号已經和各大搜尋引擎建立了密切的合作關系,你隻需要把這個類在任何搜尋引擎一搜,都能知道相關API參數的意義.

從圖中我們明白,該定時排程每次調用的時間差是

internalLockLeaseTime / 3

.也就10秒.

真相大白

寫在最後