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

Java之分布式鎖的5種實(shí)現(xiàn)過(guò)程

 更新時(shí)間:2025年09月13日 09:19:02   作者:右手嘚溫暖  
這篇文章主要介紹了Java之分布式鎖的5種實(shí)現(xiàn)過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

1、分布式鎖的基本概念

分布式鎖是在分布式系統(tǒng)環(huán)境下,控制多個(gè)進(jìn)程/服務(wù)/主機(jī)互斥訪問(wèn)共享資源的核心協(xié)調(diào)機(jī)制。

它解決了單機(jī)鎖(如Java的synchronized、ReentrantLock)在分布式場(chǎng)景下失效的問(wèn)題,是構(gòu)建可靠分布式應(yīng)用的必備工具。

解決我們?cè)诙鄠€(gè)jvm中最終只能有一個(gè)jvm執(zhí)行,從而保證了冪等性的問(wèn)題。

2、業(yè)務(wù)超時(shí),一直不釋放鎖如何處理?

可以采用續(xù)命設(shè)計(jì),續(xù)命多次,如果業(yè)務(wù)還是沒有執(zhí)行完畢,則認(rèn)為超時(shí),應(yīng)該主動(dòng)釋放該鎖,防止其他jvm一直阻塞等待。

  • (1)主動(dòng)釋放鎖;
  • (2)回滾當(dāng)前業(yè)務(wù)邏輯;
  • (3)主動(dòng)停止該線程;
  • (4)移除監(jiān)聽。

3、集群環(huán)境中保證定時(shí)任務(wù)執(zhí)行的冪等性問(wèn)題

冪等性:

  • 執(zhí)行結(jié)果保證唯一不能夠重復(fù)。
  • 當(dāng)我們定時(shí)任務(wù)服務(wù)集群的情況下,有可能會(huì)同時(shí)重復(fù)執(zhí)行定時(shí)任務(wù)

解決思路:

  • 多個(gè)jvm集群的定時(shí)任務(wù),在觸發(fā)的時(shí)候,獲取分布式鎖,
  • 如果能夠獲取到分布式鎖的jvm,就能夠執(zhí)行定時(shí)任務(wù),沒有獲取到的就不能執(zhí)行定時(shí)任務(wù)。

4、基于zookeeper實(shí)現(xiàn)分布式鎖

(1)實(shí)現(xiàn)分布式鎖思路:

因?yàn)閆ookeeper節(jié)點(diǎn)路徑保持唯一,不允許重復(fù),且有臨時(shí)節(jié)點(diǎn)特性,連接關(guān)閉后當(dāng)前節(jié)點(diǎn)會(huì)自動(dòng)消失,從而實(shí)現(xiàn)分布式鎖。

(2)實(shí)現(xiàn)原理:(臨時(shí)節(jié)點(diǎn)+事件通知)

  • 多個(gè)jvm請(qǐng)求同時(shí)創(chuàng)建相同的臨時(shí)節(jié)點(diǎn)(lockPath),只要誰(shuí)能夠創(chuàng)建成功誰(shuí)就能夠獲取到鎖;
  • 如果創(chuàng)建節(jié)點(diǎn)的時(shí)候,突然該節(jié)點(diǎn)已經(jīng)被其他請(qǐng)求創(chuàng)建的話則直接等待;
  • 只要能夠創(chuàng)建節(jié)點(diǎn)成功,則開始進(jìn)入到正常業(yè)務(wù)邏輯操作,其他沒有獲取到鎖的jvm進(jìn)行等待;
  • 正常業(yè)務(wù)邏輯流程執(zhí)行完后,調(diào)用zk關(guān)閉連接方式釋放鎖,從而使其他的請(qǐng)求開始進(jìn)入到獲取鎖的資源。

疑問(wèn):如果使用zk實(shí)現(xiàn)分布式鎖,獲取鎖之后業(yè)務(wù)邏輯方法一直沒有執(zhí)行完畢,導(dǎo)致其他所有的請(qǐng)求等待的話如何解決?

設(shè)置Session連接超時(shí)時(shí)間,在規(guī)定的時(shí)間內(nèi)獲取鎖后超時(shí)啦~自動(dòng)回滾當(dāng)前數(shù)據(jù)庫(kù)業(yè)務(wù)邏輯。

5、基于數(shù)據(jù)庫(kù)實(shí)現(xiàn)分布式鎖

(1)悲觀鎖

  • 就是先select…forupdate鎖住主鍵key_resource那個(gè)記錄,如果為空,則可以插入一條記錄,如果已有記錄判斷下狀態(tài)和時(shí)間,是否已經(jīng)超時(shí)。
  • 這里需要注意一下哈,必須要加事務(wù)哈。

(2)搞個(gè)version字段

  • 每次更新修改,都會(huì)自增加一,然后去更新余額時(shí),把查出來(lái)的那個(gè)版本號(hào),帶上條件去更新,
  • 如果是上次那個(gè)版本號(hào),就更新,如果不是,表示別人并發(fā)修改過(guò)了,就繼續(xù)重試。)

6、基于redis實(shí)現(xiàn)分布式鎖

(1)采用Setnx

Redis中SetnX與Set命令的區(qū)別

  • Setnx可以返回該key是否存在,存在返回0,不存在返回1,如果該key存在的情況下,是不能做修改的。
  • Set每次直接覆蓋該key對(duì)應(yīng)的value。

獲取鎖的原理:

  • 多個(gè)redis客戶端執(zhí)行setNx命令,設(shè)置一個(gè)相同的redis的key,誰(shuí)能創(chuàng)建key成功,誰(shuí)就能獲取鎖,
  • 如果該key已經(jīng)存在的情況下,則再創(chuàng)建的時(shí)候會(huì)返回false。

釋放鎖的原理:

  • 刪除該key。

7、基于redisson實(shí)現(xiàn)分布式鎖

多個(gè)jvm同時(shí)在redis中寫入一個(gè)相同的key,誰(shuí)能夠?qū)懭氤晒Γl(shuí)就能獲取到鎖。

(1)向redis中寫入key的時(shí)候使用lua腳本,不是setNx;

(2)如果寫入key成功,會(huì)單獨(dú)開啟一個(gè)看門狗線程(續(xù)命定時(shí)任務(wù)線程),默認(rèn)的情況下每隔10s時(shí)間不斷續(xù)命延遲。

(3)一直不斷實(shí)現(xiàn)續(xù)命的情況下,也會(huì)發(fā)生死鎖問(wèn)題,此時(shí)設(shè)定續(xù)命的次數(shù),續(xù)命多次如果業(yè)務(wù)邏輯還沒有執(zhí)行完畢,主動(dòng)回滾當(dāng)前的mysql事務(wù),并釋放該鎖。

8、基于Curator實(shí)現(xiàn)分布式鎖(解決羊群效應(yīng)問(wèn)題)

核心思想:

(1)從緩存中查找是否已經(jīng)創(chuàng)建分布式鎖,如果已經(jīng)創(chuàng)建了分布式鎖,則直接復(fù)用(具有可重入性)。

(2)如果緩存中沒有,則創(chuàng)建一個(gè)分布式鎖。

(3)實(shí)現(xiàn)原理:創(chuàng)建一個(gè)臨時(shí)節(jié)點(diǎn),獲取當(dāng)前父節(jié)點(diǎn)下的子節(jié)點(diǎn),如果是為最小的節(jié)點(diǎn),則表示獲取鎖成功,否則獲取鎖失敗,阻塞等待,則監(jiān)聽上一個(gè)節(jié)點(diǎn)。

(4)當(dāng)上一個(gè)節(jié)點(diǎn)如果釋放鎖之后,直接進(jìn)入到獲取鎖的狀態(tài),喚醒使用waitnotify技術(shù)。

總結(jié)

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

相關(guān)文章

  • Java高效提取PDF文件指定坐標(biāo)的文本內(nèi)容實(shí)戰(zhàn)代碼

    Java高效提取PDF文件指定坐標(biāo)的文本內(nèi)容實(shí)戰(zhàn)代碼

    在日常工作中,有時(shí)可能會(huì)需要從龐大的PDF文檔中提取其中所包含的文本內(nèi)容,下面這篇文章主要給大家介紹了關(guān)于如何利用Java高效提取PDF文件指定坐標(biāo)的文本內(nèi)容,需要的朋友可以參考下
    2024-01-01
  • 詳解java基于MyBatis使用示例

    詳解java基于MyBatis使用示例

    這篇文章主要介紹了詳解java基于MyBatis使用示例,對(duì)學(xué)習(xí)MyBatis有一定的幫助,有需要的可以了解一下。
    2016-11-11
  • Java設(shè)計(jì)模式之開閉原則精解

    Java設(shè)計(jì)模式之開閉原則精解

    設(shè)計(jì)模式(Design?pattern)代表了最佳的實(shí)踐,通常被有經(jīng)驗(yàn)的面向?qū)ο蟮能浖_發(fā)人員所采用。設(shè)計(jì)模式是軟件開發(fā)人員在軟件開發(fā)過(guò)程中面臨的一般問(wèn)題的解決方案。本篇介紹設(shè)計(jì)模式七大原則之一的開閉原則
    2022-02-02
  • spring boot創(chuàng)建項(xiàng)目包依賴問(wèn)題的解決

    spring boot創(chuàng)建項(xiàng)目包依賴問(wèn)題的解決

    本篇文章主要介紹了spring boot創(chuàng)建項(xiàng)目包依賴問(wèn)題的解決,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-11-11
  • Java文件(io)編程之記事本開發(fā)詳解

    Java文件(io)編程之記事本開發(fā)詳解

    這篇文章主要為大家詳細(xì)介紹了Java文件(io)編程之記事本開發(fā),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • JavaWeb中的常用的請(qǐng)求傳參注解說(shuō)明

    JavaWeb中的常用的請(qǐng)求傳參注解說(shuō)明

    這篇文章主要介紹了JavaWeb中的常用的請(qǐng)求傳參注解說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • java中利用棧實(shí)現(xiàn)字符串回文算法

    java中利用棧實(shí)現(xiàn)字符串回文算法

    給定一個(gè)由多個(gè)a和b組成的字符串?dāng)?shù)組,字符串中有一個(gè)特殊的字符X,位于字符串的正中間,例如(aaaabbbbXabaabbbb),如何判定該字符串是否回文
    2020-12-12
  • 如何處理后臺(tái)向前臺(tái)傳遞的json數(shù)據(jù)

    如何處理后臺(tái)向前臺(tái)傳遞的json數(shù)據(jù)

    這篇文章主要介紹了如何處理后臺(tái)向前臺(tái)傳遞的json數(shù)據(jù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • DUBBO 日志過(guò)濾器,輸出dubbo 接口調(diào)用入?yún)ⅰ⒊鰠⒌刃畔?最新推薦)

    DUBBO 日志過(guò)濾器,輸出dubbo 接口調(diào)用入?yún)ⅰ⒊鰠⒌刃畔?最新推薦)

    這篇文章主要介紹了DUBBO 日志過(guò)濾器,輸出dubbo 接口調(diào)用入?yún)?、出參等信?首先自定義一個(gè)過(guò)濾器?DubboLoggerFilter.java,本文結(jié)合示例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • Java SSM框架如何配置靜態(tài)資源加載

    Java SSM框架如何配置靜態(tài)資源加載

    這篇文章主要介紹了Java SSM框架如何配置靜態(tài)資源加載,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04

最新評(píng)論