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

来源:https://www.cnblogs.com/yuxiang1/archive/2019/03/13/10527028.html
-Advertisement-
Play Games

前言 上一篇[面試官問我,使用Dubbo有沒有遇到一些坑?我笑了。]之後,又有一位粉絲和我說在面試過程中被虐了.鑒於這位粉絲是之前肥朝的粉絲,而且周一又要開啟新一輪的面試,為了回饋他長期以來的支持,所以連夜寫了本篇,希望能對他接下來的面試有所幫助. 真實案例 Redis分散式鎖的正確姿勢 據肥朝瞭解 ...


前言

上一篇[面試官問我,使用Dubbo有沒有遇到一些坑?我笑了。]之後,又有一位粉絲和我說在面試過程中被虐了.鑒於這位粉絲是之前肥朝的粉絲,而且周一又要開啟新一輪的面試,為了回饋他長期以來的支持,所以連夜寫了本篇,希望能對他接下來的面試有所幫助.

真實案例

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

從這裡我們知道,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

從我圖中框起來的地方我們就知道了,獲取鎖成功就會開啟一個定時任務,也就是watchdog,定時任務會定期檢查去續期renewExpirationAsync(threadId).

這裡定時用的是netty-common包中的HashedWheelTimer,肥朝公眾號已經和各大搜索引擎建立了密切的合作關係,你只需要把這個類在任何搜索引擎一搜,都能知道相關API參數的意義.

從圖中我們明白,該定時調度每次調用的時間差是internalLockLeaseTime / 3.也就10秒.

真相大白

通過源碼分析我們知道,預設情況下,加鎖的時間是30秒.如果加鎖的業務沒有執行完,那麼到 30-10 = 20秒的時候,就會進行一次續期,把鎖重置成30秒.那這個時候可能又有同學問了,那業務的機器萬一宕機了呢?宕機了定時任務跑不了,就續不了期,那自然30秒之後鎖就解開了唄.

寫在最後

如果你是肥朝公眾號的老粉絲,並且在面試、工作過程中遇到了什麼問題,歡迎來撩.但是肥朝是個正經的Java開發,我們只調介面,不調情!

作者:肥朝

 

免費Java資料領取,涵蓋了Java、Redis、MongoDB、MySQL、Zookeeper、Spring Cloud、Dubbo/Kafka、Hadoop、Hbase、Flink等高併發分散式、大數據、機器學習等技術。
傳送門: https://mp.weixin.qq.com/s/JzddfH-7yNudmkjT0IRL8Q

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 將兩個有序鏈表合併為一個新的有序鏈表並返回。新鏈表是通過拼接給定的兩個鏈表的所有節點組成的。 示例:輸入:1->2->4, 1->3->4輸出:1->1->2->3->4->4 思路:始終讓l1是頭節點小的那一個,然後拿l2的節點值依次與l1比較並插入l1中。最後返回l1。 ...
  • def HanNuoTa(n,a,b,c):#n=盤子數 a,b,c為塔 if n == 1: print(a,"->",c) return None if n == 2: print(a,"->",b) print(a,"->",c) print(b,"->",c) return None Han ...
  • Eureka 重點在使用,概念和源碼基本不涉及 Eureka是一個基於REST(REST是HTTP協議的)的服務,主要在亞馬遜網路服務(AWS)雲中使用,定位服務來進行中間層伺服器的均衡負載和故障轉移. Spring Cloud封裝Eureka來實現服務註冊和發現,Eureka採用了C S的設計架構 ...
  • GitHub代碼練習地址:URLError:https://github.com/Neo-ML/PythonPractice/blob/master/SpiderPrac06_URLError.py HTTPError:https://github.com/Neo-ML/PythonPractice ...
  • 01B-5: 圖靈機 01B-5: 圖靈機 Which of the following is NOT a component of a Turing machine? 以下哪項不是圖靈機的組成要件? A tape of finite length 有限長的紙帶 A tape of finite l ...
  • 一、JDBC的問題 為什麼我們要使用mybatis,是因為JDBC存在以下問題 1、 資料庫連接創建、釋放頻繁造成系統資源浪費,從而影響系統性能。如果使用資料庫連接池可解決此問題。 2、 Sql語句在代碼中硬編碼,造成代碼不易維護,實際應用中sql變化的可能較大,sql變動需要改變java代碼。 3 ...
  • 1.Scrapy框架介紹 主要介紹,spiders,engine,scheduler,downloader,Item pipeline scrapy常見命令如下: 對應在scrapy文件中有,自己增加爬蟲文件,系統生成items,pipelines,setting的配置文件就這些。 items寫需要 ...
  • 超簡單Python將指定數據插入到docx模板渲染並生成 最近有一個需求,製作勞動合同表,要從excel表格中將每個人的數據導入到docx勞動合同中,重覆量很大,因此可以使用python高效解決。為了讓模板內容不變動,這裡使用了類似jinja2的渲染引擎,使用{{ }}插值表達式把數據插入進去。也可 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...