溫馨提示×

溫馨提示×

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

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

Java分布式鎖的概念與實現(xiàn)方式詳解

發(fā)布時間:2020-09-20 04:27:09 來源:腳本之家 閱讀:142 作者:李燦輝 欄目:編程語言

什么是分布式鎖?在回答這個問題之前,我們先回答一下什么是鎖。

普通的鎖,即在單機多線程環(huán)境下,當多個線程需要訪問同一個變量或代碼片段時,被訪問的變量或代碼片段叫做臨界區(qū)域,我們需要控制線程一個一個的順序執(zhí)行,否則會出現(xiàn)并發(fā)問題。

如何控制呢?就是設(shè)置一個各個線程都能看的見的標志。然后,每個線程想訪問臨界區(qū)域時,都要先查看標志,如果標志沒有被占用,則說明目前沒有線程在訪問臨界區(qū)域。如果標志被占用了,則說明目前有線程正在訪問臨界區(qū)域,則當前線程需要等待。

這個標志,就是鎖。

在單機多線程的java程序中,我們可以使用堆內(nèi)存中的變量作為標志,因為多線程是共享堆內(nèi)存的,堆內(nèi)存中的變量對于各個線程都是可見的。

講明白了普通的鎖,接下來,我們再看看分布式鎖。

在分布式環(huán)境下,即多臺計算機,每個計算機上會啟動jvm執(zhí)行程序的運行環(huán)境下,如果不同計算機上的線程想訪問臨界區(qū)域時,該怎么辦呢?

前面普通鎖的使用堆內(nèi)存中的變量的方式肯定不適用了。因為在多機環(huán)境下,某臺計算機上的堆內(nèi)存中的變量對于其他計算機上的線程肯定是不可見的。那么,根據(jù)鎖的本質(zhì)和原理,我們就要找到另外的對于多機上的線程都可見的標志,以它來作為鎖,就可以了。這樣的鎖,就是分布式鎖。

當然,這里只是解釋了什么是分布式鎖,至于分布式鎖該如何實現(xiàn),其實有多重方式,關(guān)鍵在于要保證鎖對多機上的程序是可見的即可。一些常用的實現(xiàn)方式是,使用redis,使用數(shù)據(jù)庫等等。

為什么要使用分布式鎖

我們在開發(fā)應(yīng)用的時候,如果需要對某一個共享變量進行多線程同步訪問的時候,可以使用我們學(xué)到的Java多線程的18般武藝進行處理,并且可以完美的運行,毫無Bug!

注意這是單機應(yīng)用,也就是所有的請求都會分配到當前服務(wù)器的JVM內(nèi)部,然后映射為操作系統(tǒng)的線程進行處理!而這個共享變量只是在這個JVM內(nèi)部的一塊內(nèi)存空間!

分布式鎖應(yīng)該具備哪些條件

在分析分布式鎖的三種實現(xiàn)方式之前,先了解一下分布式鎖應(yīng)該具備哪些條件:

  • 1、在分布式系統(tǒng)環(huán)境下,一個方法在同一時間只能被一個機器的一個線程執(zhí)行;
  • 2、高可用的獲取鎖與釋放鎖;
  • 3、高性能的獲取鎖與釋放鎖;
  • 4、具備可重入特性;
  • 5、具備鎖失效機制,防止死鎖;
  • 6、具備非阻塞鎖特性,即沒有獲取到鎖將直接返回獲取鎖失敗。

分布式鎖的三種實現(xiàn)方式

目前幾乎很多大型網(wǎng)站及應(yīng)用都是分布式部署的,分布式場景中的數(shù)據(jù)一致性問題一直是一個比較重要的話題。分布式的CAP理論告訴我們“任何一個分布式系統(tǒng)都無法同時滿足一致性(Consistency)、可用性(Availability)和分區(qū)容錯性(Partition tolerance),最多只能同時滿足兩項?!彼裕芏嘞到y(tǒng)在設(shè)計之初就要對這三者做出取舍。在互聯(lián)網(wǎng)領(lǐng)域的絕大多數(shù)的場景中,都需要犧牲強一致性來換取系統(tǒng)的高可用性,系統(tǒng)往往只需要保證“最終一致性”,只要這個最終時間是在用戶可以接受的范圍內(nèi)即可。

在很多場景中,我們?yōu)榱吮WC數(shù)據(jù)的最終一致性,需要很多的技術(shù)方案來支持,比如分布式事務(wù)、分布式鎖等。有的時候,我們需要保證一個方法在同一時間內(nèi)只能被同一個線程執(zhí)行。

  • 基于數(shù)據(jù)庫實現(xiàn)分布式鎖;
  • 基于緩存(Redis等)實現(xiàn)分布式鎖;
  • 基于Zookeeper實現(xiàn)分布式鎖;

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對億速云的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

向AI問一下細節(jié)

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

AI