什么是分布式鎖?在回答這個問題之前,我們先回答一下什么是鎖。
普通的鎖,即在單機多線程環(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)存空間!
想了解更多相關(guān)資訊請關(guān)注java培訓(xùn)頻道-查看更多,了解相關(guān)專業(yè)課程信息您可在線咨詢也可免費申請試課。關(guān)注賦能網(wǎng)了解更多:4008-569-579
本文鏈接:
本文章“Java學(xué)習分布式鎖的概念及使用目的解析”已幫助 90 人
免責聲明:本信息由用戶發(fā)布,本站不承擔本信息引起的任何交易及知識產(chǎn)權(quán)侵權(quán)的法律責任!
本文由賦能網(wǎng) 整理發(fā)布。了解更多培訓(xùn)機構(gòu)》培訓(xùn)課程》學(xué)習資訊》課程優(yōu)惠》課程開班》學(xué)校地址等機構(gòu)信息,可以留下您的聯(lián)系方式,讓課程老師跟你詳細解答:
咨詢熱線:4008-569-579