国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Redis > 正文

基于Redis的分布式鎖的簡單實現方法

2020-03-17 12:19:46
字體:
來源:轉載
供稿:網友

Redis官方給出兩種思路

第一種:SET key value [EX seconds] [PX milliseconds] NX

第二種:SETNX+GETSET

首先,分別看一下這幾個命令

SET命令

Redis,分布式鎖

Redis,分布式鎖

SETNX命令

Redis,分布式鎖

Redis,分布式鎖

GETSET命令

Redis,分布式鎖

Redis,分布式鎖

接著,看第一種方式

官方給出的思路是這樣的

Redis,分布式鎖

還有一處,也是類似的

Redis,分布式鎖

這種方式的實現可能是這樣的:

Redis,分布式鎖

Redis,分布式鎖

第二種方式

官方給出的思路是這樣的

Redis,分布式鎖

代碼可能看起來像是這樣

Redis,分布式鎖

總結:

這兩種方式的基本思路都是:客戶端在服務器上設置一個key值,如果能夠設置成功,則視為加鎖成功;刪除key,則表示解鎖。

不同之處在于,SET方式只需判斷能不能設置成功,刪除的時候判斷是不是自己設置的,萬一超時了利用系統自帶的生存時間可以自動釋放鎖。

而SETNX+GETSET方式除了需要判斷能不能設置成功,在設置失敗的時候還要進一步判斷其值是否有效,是否超時由客戶端自己判斷

Redis,分布式鎖

參考 https://redis.io/topics/distlock

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Redis頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 赤城县| 望谟县| 报价| 应用必备| 横山县| 禹城市| 塔城市| 丹巴县| 合山市| 天津市| 兴化市| 垦利县| 石河子市| 城市| 泰州市| 周宁县| 云霄县| 阜宁县| 常熟市| 平湖市| 石河子市| 新宁县| 玉山县| 牙克石市| 临城县| 达尔| 云安县| 中阳县| 姚安县| 庆元县| 临沭县| 嘉祥县| 商洛市| 东辽县| 淮阳县| 自治县| 麻栗坡县| 巧家县| 乐业县| 新沂市| 新绛县|