国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Redis實現分布式鎖的幾種方案

數據庫 Redis
對于Redis實現分布式鎖的幾種方案這個話題,展開之前我想先簡單聊聊什么是分布式鎖,分布式鎖的使用場景,除了Redis外還有什么技術實現分布式鎖等一系列內容。

1.前言

對于Redis實現分布式鎖的幾種方案這個話題,展開之前我想先簡單聊聊什么是分布式鎖,分布式鎖的使用場景,除了Redis外還有什么技術實現分布式鎖等一系列內容。

1.1分布式鎖

說大一點,就是在現在發展越來越迅速的大背景下,去中心化分布式系統越來越普及,在我們實際的生產開發當中,有一種不可避免的場景就是多個進程互斥的對其資源的使用,為了保證數據不重復,要求在同一時刻,同一任務只在一個節點上運行,且保證在多進程下的數據安全,分布式鎖就十分重要了。

1.2分布式鎖的幾種方案

方式有很多種,根據技術角度的不同

有基于MySQL的方式,通過表的唯一索引,通過insert和delete就可以實現加鎖和解鎖的效果;

有基于zookeeper的方式,通過創建臨時有序節點,判斷創建的節點序號是否最小。若是,則表示獲取到鎖,不是,則watch /lock目錄下序號比自身小的前一個節點,解鎖只需要刪除節點;

有基于Redis的方式。通過執行setnx,若成功再執行expire添加過期時間的方式加鎖,解鎖執行delete命令。

方式有很多,不一一列舉了。

1.3Redis分布式鎖需要滿足的條件

  • 互斥性。在任意時刻,只有一個客戶端能持有鎖。
  • 不發生死鎖。即使有一個客戶端在持有鎖的期間崩潰而沒有主動解鎖也能保證后續其他客戶端能加鎖。
  • 同一性。加鎖和解鎖必須是同一個客戶端,客戶端自己不能把別人加的鎖給解了,即不能誤解鎖。
  • 容錯性。只要大多數Redis節點正常運行,客戶端就能夠獲取和釋放鎖。

2.Redis實現分布式鎖的幾種方案

可以通過以下方式實現(包括但不限于):

  • SETNX + EXPIRE
  • SETNX + value(系統時間+過期時間)
  • 通過開源框架-Redisson

簡單來說說,用Java代碼演示:

2.1 SETNX + EXPIRE

setnx(SET IF NOT EXISTS)+ expire命令。先用setnx來搶鎖,如果搶到鎖,再用expire給鎖設置一個過期時間,這樣持有鎖超時時釋放鎖,防止鎖忘記釋放。但此時setnx和expire兩個命令無法保證原子性,例如:

if(jedis.setnx(key_resource_id,lock_value) == 1){ //加鎖
expire(key_resource_id,100); //設置過期時間
try {
//業務代碼塊
}catch() {
}finally {
jedis.del(key_resource_id); //釋放鎖
}
}

2.2 SETNX + value(系統時間+過期時間)

可以把過期時間放到setnx的value值里面。如果加鎖失敗,再拿出value值校驗一下即可。加鎖代碼如下:

long expires = System.currentTimeMillis() + expireTime; //系統時間+設置的過期時間
String expiresStr = String.valueOf(expires);
// 如果當前鎖不存在,則加鎖成功
if (jedis.setnx(key_resource_id, expiresStr) == 1) {
return true;
}
// 如果鎖已經存在,獲取鎖的過期時間
String currentValueStr = jedis.get(key_resource_id);

// 如果獲取到的過期時間,小于系統當前時間,表示已經過期
if (currentValueStr != null && Long.parseLong(currentValueStr) < System.currentTimeMillis()) {
// 鎖已過期,獲取上一個鎖的過期時間,并設置現在鎖的過期時間
String oldValueStr = jedis.getSet(key_resource_id, expiresStr);
if (oldValueStr != null && oldValueStr.equals(currentValueStr)) {
// 考慮多線程并發的情況,只有一個線程的設置值和當前值相同,它才可以加鎖
return true;
}
}
//其他情況均返回加鎖失敗
return false;

2.3 通過開源框架-Redisson

那么此時就要去想了,如果已經超過了加鎖的過期時間,可是業務還沒執行完成,這個時候怎么做呢?是把過期時間延長嗎?顯然不合理,可以通過開源框架-Redisson優化這個問題,簡單來說,Redisson就是當一個線程獲得鎖以后,給該線程開啟一個定時守護線程,每隔一段時間檢查鎖是否還存在,存在則對鎖的過期時間延長,防止鎖過期提前釋放。假設兩個線程爭奪統一公共資源:線程A獲取鎖,并通過哈希算法選擇節點,執行Lua腳本加鎖,同時其看門狗機制會啟動一個watch dog(后臺線程),每隔10秒檢查線程,如果線程A還持有鎖,那么就會不斷的延長鎖key的生存時間。線程B獲得鎖失敗,就會訂閱解鎖消息,當獲取鎖到剩余過期時間后,調用信號量方法阻塞住,直到被喚醒或等待超時。一旦線程A釋放了鎖,就會廣播解鎖消息。于是,解鎖消息的監聽器會釋放信號量,獲取鎖被阻塞的線程B就會被喚醒,并重新嘗試獲取鎖。

Redisson 支持單點模式、主從模式、哨兵模式、集群模式,假設現為單點模式:

//構造Config
Config config = new Config();
config.useSingleServer().setAddress("redis://ip:port").setPassword("Password.~#").setDatabase(0);
//構造RedissonClient
RedissonClient redissonClient = Redisson.create(config);
//獲取鎖實例
RLock rLock = redissonClient.getLock(lockKey);
try {
//獲取鎖,waitTimeout為最大等待時間,超過這個值,則認為獲取鎖失敗。leaseTime為鎖的持有時間
boolean res = rLock.tryLock((long)waitTimeout, (long)leaseTime, TimeUnit.SECONDS);
if (res) {
//業務塊
}
} catch (Exception e) {
}finally{
//解鎖
rLock.unlock();
}

3.小結

Redis的分布式鎖實現方式有很多,這里不一一列舉了,有機會再展開Lua腳本、分布式鎖Redlock等內容。

責任編輯:武曉燕 來源: GreatSQL社區
相關推薦

2023-08-21 19:10:34

Redis分布式

2022-01-06 10:58:07

Redis數據分布式鎖

2019-06-19 15:40:06

分布式鎖RedisJava

2019-02-26 09:51:52

分布式鎖RedisZookeeper

2023-04-03 10:00:00

Redis分布式

2024-04-01 05:10:00

Redis數據庫分布式鎖

2022-05-18 10:38:51

Redis分布式鎖數據

2024-10-07 10:07:31

2022-02-10 08:57:45

分布式線程鎖

2023-10-11 09:37:54

Redis分布式系統

2024-11-28 15:11:28

2019-12-25 14:35:33

分布式架構系統

2020-07-30 09:35:09

Redis分布式鎖數據庫

2020-07-15 16:50:57

Spring BootRedisJava

2023-01-13 07:39:07

2022-06-16 08:01:24

redis分布式鎖

2022-03-04 09:54:04

Redis分布式鎖腳本

2023-09-28 08:39:23

分布式鎖Redis

2021-02-28 07:49:28

Zookeeper分布式

2017-01-16 14:13:37

分布式數據庫
點贊
收藏

51CTO技術棧公眾號

俄罗斯精品一区二区三区| 国产第一页在线视频| 欧美精品一区男女天堂| 一区二区三区午夜视频| 欧美日韩亚洲自拍| 最新中文字幕亚洲| 国产揄拍国内精品对白| 日本高清成人vr专区| 国产欧美日韩综合精品二区| 欧美性猛交xxxx黑人猛交| 国产欧美日韩在线一区二区| 男人艹女人在线观看| 久久久久久久久电影| 欧美激情一二三区| 日韩视频一区二区三区四区| 日韩精品―中文字幕| 色阁综合伊人av| 99精品国产91久久久久久 | 欧美色播在线播放| 日韩精品首页| 特黄特色大片免费视频大全| 国产精品7m视频| 樱桃视频在线观看一区| 中文有码一区| 亚洲一区二区三区成人| 1卡2卡3卡精品视频| 91传媒视频在线播放| 18成人免费观看视频| 搞黄视频免费在线观看| 精品999在线观看| 精品sm捆绑视频| 国产成人免费在线观看| 欧美91在线|欧美| 欧美日韩一区二区三区69堂| 国产精品免费一区豆花| 在线免费av一区| 日韩一区欧美二区| 国产私拍福利精品视频二区| 成人黄色一区二区| 国产精品成人va在线观看| 欧美性猛交xxxx黑人| 免费在线日韩av| 欧美va在线观看| 三级视频中文字幕| 成人美女免费网站视频| 欧美丰满少妇xxxbbb| 国产呦萝稀缺另类资源| av一级亚洲| 香蕉av在线| 亚洲开发第一视频在线播放| 中文字幕亚洲一区二区三区五十路 | 精品国产三区在线| 中文字幕在线播放网址| 天天干夜夜干| 爆操妹子视频在线观看| 中文字幕第38页| 春日野结衣av| 日韩人妻无码精品久久久不卡| 日产精品一线二线三线芒果| 中文字幕一区综合| 日本一区精品| 亚洲国产精品毛片| 成人网址在线观看| 国产精品吴梦梦| 国产成人精品综合| 水蜜桃亚洲一二三四在线| 中国大陆高清aⅴ毛片| 免费看成人哺乳视频网站| 国产无遮挡又黄又爽免费网站| 成人福利网站在线观看11| 日韩视频永久免费| 亚洲不卡中文字幕无码| 日本a在线天堂| 中文字幕免费在线| 国产精品国产一区| 国产三级视频在线看| 一区二区三区四区视频在线观看 | 高跟丝袜欧美一区| 麻豆精品精品国产自在97香蕉| 秋霞影院一区| av网站无病毒在线| 成人综合视频在线| 粉嫩av四季av绯色av第一区| 国产亚洲日本欧美韩国| 一区二区三区不卡在线观看 | 日韩精品成人一区二区三区| crdy在线观看欧美| 九九在线视频| 国产欧美高清在线| 加勒比在线一区二区三区观看| 久久天天躁狠狠躁夜夜躁| 在线一区二区三区做爰视频网站| 成人爱爱电影网址| 1024日韩| 日日狠狠久久偷偷综合色| 国产蜜臀在线| 午夜黄色一级片| 欧美一级欧美一级| 国产区二精品视| 91成人天堂久久成人| 亚洲精品一区二区三区精华液| 亚洲日本电影在线| 国产精品一区二区x88av| 一区二区电影| 8x国产一区二区三区精品推荐| gogogogo高清视频在线| 男人在线视频资源| 国产乱人伦精品一区二区三区| www.久久草| 午夜精品一区二区三区在线播放| 亚洲第一色中文字幕| 疯狂欧美牲乱大交777| 久久精品视频在线看| 奇米精品一区二区三区在线观看一| 狠狠操综合网| 欧美亚洲日本精品| 欧美1区免费| 国产黄人亚洲片| 日韩一区二区在线观看视频播放| 91美女高潮出水| 日本新janpanese乱熟| 最新日韩三级| 青青草视频一区| 在线观看视频欧美| 国产精品美女午夜av| 凹凸国产熟女精品视频| 高清视频在线观看三级| 美女国产精品| 欧美在线综合视频| 一区二区精品在线观看| 电影午夜精品一区二区三区| 91精彩视频在线观看| 91国内外精品自在线播放| 一本色道久久综合狠狠躁的番外| 日本网站在线观看一区二区三区| 欧美日韩亚洲一区二区| 欧美一区三区二区在线观看| 国产精品主播在线观看| 99re热在线观看| 国产美女作爱全过程免费视频| 日本不卡在线观看| 国产精品对白刺激久久久| 国产成人97精品免费看片| 久久久999国产| 亚洲激情自拍视频| 国产成人啪精品视频免费网| 成全视频在线播放大地| 日韩精品福利一区二区三区| 日韩av一区二区三区四区| 欧美丝袜丝交足nylons| 久久久久久99| www555久久| 亚洲欧美日韩久久精品| 777视频在线观看| 久久久久久久久久久久久国产精品| 一级黄色片播放| 亚洲巨乳在线观看| 性欧美精品一区二区三区在线播放| 免费久久一级欧美特大黄 | 不卡的看片网站| 国产成人一区二区精品非洲| 国产美女精品一区二区三区| 黄色小说综合网站| 国产美女一区二区| 成人激情午夜影院| 26uuu国产电影一区二区| 久久久久久久久久久99999| 久久精品欧美日韩精品| 中文字幕一区二区三区精华液 | 久久这里精品| 国产在线中文字幕| 成人高清免费在线播放| 成人精品一区二区三区校园激情| 爱久久·www| 乱人伦中文视频在线| av在线播放国产| 国产网红在线观看| 人人草在线视频| 日韩三级一区| 天堂成人娱乐在线视频免费播放网站| 国产伦精品一区二区三区视频| 国产精品久久天天影视| 亚洲人体偷拍| 久久激情综合网| 99久久精品一区二区| 国产日韩欧美一区二区三区乱码| 国产精品精品国产色婷婷| 亚洲第一影院| 亚洲成在线观看| 播放灌醉水嫩大学生国内精品| 精品视频99| 91精品国产91热久久久做人人| 欧美国产亚洲一区| 精品亚洲porn| 99porn视频在线| 欧美日中文字幕| 国产情人节一区| 在线视频中文亚洲| 久久久免费观看视频| 国产精品久久久久久久久男 |