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

首頁 > 數據庫 > Redis > 正文

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

2020-10-28 21:31:40
字體:
來源:轉載
供稿:網友

Redis官方給出兩種思路

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

第二種:SETNX+GETSET

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

SET命令

SETNX命令

GETSET命令

接著,看第一種方式

官方給出的思路是這樣的

還有一處,也是類似的

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

第二種方式

官方給出的思路是這樣的

代碼可能看起來像是這樣

總結:

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

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

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

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 松阳县| 深州市| 隆德县| 育儿| 延安市| 图片| 山西省| 灌阳县| 堆龙德庆县| 托克逊县| 涿州市| 湟源县| 和田市| 广元市| 报价| 富裕县| 安国市| 获嘉县| 洛宁县| 石渠县| 景洪市| 博爱县| 麦盖提县| 盐边县| 梧州市| 阿克苏市| 大丰市| 通山县| 喀喇沁旗| 萨嘎县| 杭州市| 喜德县| 贵定县| 大厂| 三都| 仲巴县| 雷山县| 大庆市| 墨脱县| 时尚| 思南县|