麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

redis分布式鎖處理并發問題

2019-11-14 09:02:04
字體:
來源:轉載
供稿:網友

redis鎖處理并發問題

redis鎖處理高并發問題十分常見,使用的時候常見有幾種錯誤,和對應的解決辦法,在此進行自己的總結和整理。

set方式setnx方式setnx+getset方式

set方式 作為redis小白,一開始能想到的使用redis加鎖的方式就是set。 加鎖:redis中set一個值,set(lock,1); 并發處理:其他線程必須拿到這個值,才可以往下進行,否則等待。

while(jedis.exists(lock)){ Thread.sleep(500); } set(lock,1); 執行業務代碼; jedis.del(lock);

釋放鎖:執行完業務代碼之后,釋放redis鎖,jedis.del(lock) 防止死鎖:set(lock,1) —>3秒后未釋放,則自動釋放setex(lock, 3, 1) 問題:高并發情況下,進程同時獲取鎖狀態為null,同時設置,鎖之間相互覆蓋,但是倆進程仍在并發執行業務代碼。 setnx方式 后來發現有setnx的原子操作命令,鎖存在不能設置值,返回0;鎖不存在,則設置鎖,返回1; 加鎖:jedis.setnx(lock, 1) 并發處理:

while(jedis.setnx(lock,1)==0){ Thread.sleep(300);}執行業務代碼;jedis.del(lock);

釋放鎖:執行完業務代碼之后,釋放redis鎖,jedis.del(lock) 問題:當進程執行出現問題,鎖未釋放,則其他進程永遠處于阻塞狀態,出現死鎖。 防止死鎖:加鎖時帶上時間戳,setnx(lock, 時間戳+超時時間)

while(jedis.setnx(lock,now+超時時間)==0){ if(jedis.get(lock)<now){ jedis.del(lock); jedis.setnx(lock,now+超時時間); break; }else{ Thread.sleep(300); } } 執行業務代碼; jedis.del(lock);

問題:當倆進程同時讀到發現鎖超時,都去釋放鎖,相互覆蓋,則倆進程同時獲得鎖,仍并發執行業務代碼。 setnx+getset方式 為解決上面的問題,可以使用getset命令,getset設置鍵值,并返回原來的鍵值。 加鎖:setnx(lock, 時間戳+超時時間) 解決并發:

while(jedis.setnx(lock, now+超時時間)==0){ if(now>jedis.get(lock) && now>jedis.getset(lock, now+超時時間)){ break; }else{ Thread.sleep(300); }}執行業務代碼;jedis.del(lock);

釋放鎖:jedis.del(lock);


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久免费观看一级毛片 | 欧美性生活区 | 美国黄色毛片女人性生活片 | 免费亚洲视频在线观看 | 日本搞逼视频 | 调教小男生抽打尿孔嗯啊视频 | 99这里精品 | 国产1区2区在线观看 | 成人午夜视屏 | 九九热在线视频观看 | chengrenzaixian| 精品一区二区三区欧美 | 国产成人精品自拍视频 | 在线 日本 制服 中文 欧美 | 性片免费看 | 日本黄色大片免费 | 日韩欧美精品电影 | 亚洲午夜在线 | 亚洲第一成人av | 免费国产一级淫片 | 成人做爰高潮片免费视频韩国 | 色综合久久久久久久久久久 | 国产成人在线视频播放 | 97porn| 亚洲成人欧美 | 久久人添人人爽人人爽人人片av | 国产精品白嫩白嫩大学美女 | 日韩理论电影网 | 国产一级在线观看视频 | hdjapanesemassagehd日本| 一级视频片 | 可以看毛片的网址 | 成人aaaa免费全部观看 | 免费三级大片 | 免费黄色小网站 | 欧美日韩在线看片 | av电影在线观看网站 | 九九热在线精品视频 | 国产乱淫a∨片免费观看 | 一级看片免费视频 | 国产91亚洲精品久久久 |