久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > redis分布式鎖三種方式:redis分布式鎖可能出現(xiàn)的問(wèn)題

redis分布式鎖三種方式:redis分布式鎖可能出現(xiàn)的問(wèn)題

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-07-23 13:16:10 1690089370

Redis作為一種常用的緩存系統(tǒng),具有高速、可擴(kuò)展性強(qiáng)的特點(diǎn),常用來(lái)進(jìn)行分布式鎖的設(shè)計(jì)。在Redis中,有三種不同的實(shí)現(xiàn)分布式鎖的方式。

方式一:SETNX

SETNX是Redis中最為原始的實(shí)現(xiàn)分布式鎖的方式。其本質(zhì)原理是使用Redis的SETNX(SET if Not eXists)命令,去嘗試獲取鎖。

代碼實(shí)現(xiàn)如下:

SET key value EX seconds NX

其中key為鎖名稱,value為隨機(jī)字符串,seconds表示鎖的過(guò)期時(shí)間,NX表示只有key不存在時(shí),才會(huì)成功執(zhí)行SET命令。

這種方式的好處是簡(jiǎn)單、易于實(shí)現(xiàn)。但是不足之處是,如果在SETNX成功獲取到鎖后,在unlock之前出現(xiàn)程序異常或者運(yùn)行時(shí)間過(guò)大導(dǎo)致鎖過(guò)期,就會(huì)出現(xiàn)鎖被其它程序搶占的情況。

方式二:SETNX和GETSET

為了解決方式一出現(xiàn)的問(wèn)題,出現(xiàn)了SETNX和GETSET的組合使用方式。

代碼實(shí)現(xiàn)如下:

SETNX key valueGETSET key value

首先使用SETNX嘗試獲取鎖,如果返回成功,則執(zhí)行GETSET命令,即設(shè)置新的隨機(jī)值,并獲取上一次的值。然后我們?cè)倏瓷鲜龃a后面可不可以加一個(gè)比較操作,提供一種解決缺點(diǎn)的思路,即:

if (preValue == curValue)    ret true;else    removeLock();    ret false;

這種方式可以解決方式一中的問(wèn)題,但是其不足之處是,如果獲取鎖的程序掛掉或者崩潰,鎖將永遠(yuǎn)無(wú)法被釋放。

方式三:Redisson

為了解決方式二出現(xiàn)的問(wèn)題,Redisson框架被提出并廣泛使用。它是基于Redis的分布式Java數(shù)據(jù)容器和一種常用的分布式鎖解決方案,提供了多種分布式鎖實(shí)現(xiàn)方法。

Redisson提供了3種分布式鎖實(shí)現(xiàn)方式:

普通鎖(同步鎖)

RLock(可重入鎖)

RedLock(多重鎖)

這種方式可以解決方式二的所有問(wèn)題,而且還可以方便的獲得鎖的狀態(tài)信息,如獲得鎖的時(shí)間、鎖的持有者等。

總結(jié)

在Redis中,分布式鎖的實(shí)現(xiàn)方法有三種,其中每種方式都有其優(yōu)缺點(diǎn)。SETNX和GETSET的組合方式,是一種比較原始的方式,思路簡(jiǎn)單,易于實(shí)現(xiàn),但是存在程序異?;蛘邥r(shí)間過(guò)長(zhǎng)導(dǎo)致鎖過(guò)期等風(fēng)險(xiǎn)。Redisson框架則提供了多種分布式鎖實(shí)現(xiàn)方法,使用起來(lái)方便,支持可重入鎖和多重鎖等,是目前比較優(yōu)秀的分布式鎖。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
敏捷落地有哪些好用的軟件?

一、JIRA項(xiàng)目管理:JIRA是Atlassian推出的項(xiàng)目管理工具,專為敏捷開(kāi)發(fā)團(tuán)隊(duì)設(shè)計(jì),提供敏捷項(xiàng)目管理、缺陷跟蹤等功能。敏捷支持:支持多種敏捷方...詳情>>

2023-10-15 20:00:25
項(xiàng)目報(bào)工系統(tǒng)有哪些?

一、項(xiàng)目進(jìn)度管理項(xiàng)目報(bào)工系統(tǒng)通過(guò)項(xiàng)目進(jìn)度管理確保了工作流的順利進(jìn)行。以下是其主要內(nèi)容:任務(wù)劃分與排期:允許項(xiàng)目經(jīng)理和團(tuán)隊(duì)成員將整個(gè)項(xiàng)目...詳情>>

2023-10-15 19:48:56
APP開(kāi)發(fā)中APICloud界面布局都是由哪些組成的?

1、HTML5與CSS3構(gòu)建界面: 使用HTML5構(gòu)建界面的基本結(jié)構(gòu)樣式設(shè)計(jì): 通過(guò)CSS3來(lái)創(chuàng)建各種動(dòng)態(tài)效果和響應(yīng)式設(shè)計(jì)2、UI組件庫(kù)常用控件: 包括按鈕、滑塊...詳情>>

2023-10-15 19:36:35
有哪些比較好的圖像標(biāo)注工具?

一、Labelbox多功能標(biāo)注:支持各種標(biāo)注類型,如分割、檢測(cè)等。 團(tuán)隊(duì)協(xié)作:Labelbox具有團(tuán)隊(duì)協(xié)作功能,可共享項(xiàng)目和注釋。二、RectLabel專業(yè)選擇...詳情>>

2023-10-15 19:29:47
APAUTOSAR平臺(tái)有哪些優(yōu)勢(shì)?

一、可擴(kuò)展性 APAUTOSAR提供了靈活的架構(gòu)設(shè)計(jì),能夠支持各種電子控制單元(ECU)架構(gòu)和硬件。硬件無(wú)關(guān): 允許在不同供應(yīng)商的硬件上部署。適應(yīng)未...詳情>>

2023-10-15 19:26:29
快速通道