成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > Redis 實(shí)現(xiàn)同步鎖案例

Redis 實(shí)現(xiàn)同步鎖案例

熱門標(biāo)簽:超呼電話機(jī)器人 山東外呼銷售系統(tǒng)招商 貴州電銷卡外呼系統(tǒng) 宿遷便宜外呼系統(tǒng)平臺(tái) 鄭州人工智能電銷機(jī)器人系統(tǒng) 魔獸2青云地圖標(biāo)注 北京400電話辦理收費(fèi)標(biāo)準(zhǔn) 日本中國(guó)地圖標(biāo)注 十堰營(yíng)銷電銷機(jī)器人哪家便宜

1、技術(shù)方案

1.1、redis的基本命令

1)SETNX命令(SET if Not eXists)

語(yǔ)法:SETNX key value

功能:當(dāng)且僅當(dāng) key 不存在,將 key 的值設(shè)為 value ,并返回1;若給定的 key 已經(jīng)存在,則 SETNX 不做任何動(dòng)作,并返回0。

2)expire命令

語(yǔ)法:expire KEY seconds

功能:設(shè)置key的過(guò)期時(shí)間。如果key已過(guò)期,將會(huì)被自動(dòng)刪除。

3)DEL命令

語(yǔ)法:DEL key [KEY …]

功能:刪除給定的一個(gè)或多個(gè) key ,不存在的 key 會(huì)被忽略。

1.2、實(shí)現(xiàn)同步鎖原理

1)加鎖:“鎖”就是一個(gè)存儲(chǔ)在redis里的key-value對(duì),key是把一組投資操作用字符串來(lái)形成唯一標(biāo)識(shí),value其實(shí)并不重要,因?yàn)橹灰@個(gè)唯一的key-value存在,就表示這個(gè)操作已經(jīng)上鎖。

2)解鎖:既然key-value對(duì)存在就表示上鎖,那么釋放鎖就自然是在redis里刪除key-value對(duì)。

3)阻塞、非阻塞:阻塞式的實(shí)現(xiàn),若線程發(fā)現(xiàn)已經(jīng)上鎖,會(huì)在特定時(shí)間內(nèi)輪詢鎖。非阻塞式的實(shí)現(xiàn),若發(fā)現(xiàn)線程已經(jīng)上鎖,則直接返回。

4)處理異常情況:假設(shè)當(dāng)投資操作調(diào)用其他平臺(tái)接口出現(xiàn)等待時(shí),自然沒有釋放鎖,這種情況下加入鎖超時(shí)機(jī)制,用redis的expire命令為key設(shè)置超時(shí)時(shí)長(zhǎng),過(guò)了超時(shí)時(shí)間redis就會(huì)將這個(gè)key自動(dòng)刪除,即強(qiáng)制釋放鎖

(此步驟需在JAVA內(nèi)部設(shè)置同樣的超時(shí)機(jī)制,內(nèi)部超時(shí)時(shí)長(zhǎng)應(yīng)小于或等于redis超時(shí)時(shí)長(zhǎng))。

1.3、處理流程圖  

2、代碼實(shí)現(xiàn)

2.1、同步鎖工具類

package com.mic.synchrolock.util;
import java.util.ArrayList;
import java.util.List;
import java.util.UUID;
import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.beans.factory.annotation.Autowired;
import com.mic.constants.Constants;
import com.mic.constants.InvestType;
/**
 * 分布式同步鎖工具類
 * @author Administrator
 *
 */
public class SynchrolockUtil {
 private final Log logger = LogFactory.getLog(getClass());
 @Autowired
 private RedisClientTemplate redisClientTemplate;
 public final String RETRYTYPE_WAIT = "1";  //加鎖方法當(dāng)對(duì)象已加鎖時(shí),設(shè)置為等待并輪詢
 public final String RETRYTYPE_NOWAIT = "0";  //加鎖方法當(dāng)對(duì)象已加鎖時(shí),設(shè)置為直接返回
 private String requestTimeOutName = "";  //投資同步鎖請(qǐng)求超時(shí)時(shí)間
 private String retryIntervalName = "";   //投資同步鎖輪詢間隔
 private String keyTimeoutName = "";  //緩存中key的失效時(shí)間
 private String investProductSn = "";   //產(chǎn)品Sn
 private String uuid;    //對(duì)象唯一標(biāo)識(shí)
 private Long startTime = System.currentTimeMillis(); //首次調(diào)用時(shí)間
 public Long getStartTime() {
  return startTime;
 }
 ListString> keyList = new ArrayListString>(); //緩存key的保存集合
 public ListString> getKeyList() {
  return keyList;
 }
 public void setKeyList(ListString> keyList) {
  this.keyList = keyList;
 }
 @PostConstruct
 public void init() {
  uuid = UUID.randomUUID().toString();
 }
 @PreDestroy
 public void destroy() {
  this.unlock();
 }
 /**
  * 根據(jù)傳入key值,判斷緩存中是否存在該key
  * 存在-已上鎖:判斷retryType,輪詢超時(shí),或直接返回,返回ture
  * 不存在-未上鎖:將該放入緩存,返回false
  * @param key
  * @param retryType 當(dāng)遇到上鎖情況時(shí) 1:輪詢;0:直接返回
  * @return
  */
 public boolean islocked(String key,String retryType){
  boolean flag = true;
  logger.info("====投資同步鎖設(shè)置輪詢間隔、請(qǐng)求超時(shí)時(shí)長(zhǎng)、緩存key失效時(shí)長(zhǎng)====");
  //投資同步鎖輪詢間隔 毫秒
  Long retryInterval = Long.parseLong(Constants.getProperty(retryIntervalName));
  //投資同步鎖請(qǐng)求超時(shí)時(shí)間 毫秒
  Long requestTimeOut = Long.parseLong(Constants.getProperty(requestTimeOutName));
  //緩存中key的失效時(shí)間 秒
  Integer keyTimeout = Integer.parseInt(Constants.getProperty(keyTimeoutName));
  //調(diào)用緩存獲取當(dāng)前產(chǎn)品鎖
  logger.info("====當(dāng)前產(chǎn)品key為:"+key+"====");
  if(isLockedInRedis(key,keyTimeout)){
   if("1".equals(retryType)){
    //采用輪詢方式等待
    while (true) {
     logger.info("====產(chǎn)品已被占用,開始輪詢====");
     try {
      Thread.sleep(retryInterval);
     } catch (InterruptedException e) {
      logger.error("線程睡眠異常:"+e.getMessage(), e);
      return flag;
     }
     logger.info("====判斷請(qǐng)求是否超時(shí)====");
     Long currentTime = System.currentTimeMillis(); //當(dāng)前調(diào)用時(shí)間
     long Interval = currentTime - startTime;
     if (Interval > requestTimeOut) {
      logger.info("====請(qǐng)求超時(shí)====");
      return flag;
     }
     if(!isLockedInRedis(key,keyTimeout)){
      logger.info("====輪詢結(jié)束,添加同步鎖====");
      flag = false;
      keyList.add(key);
      break;
     }
    }
   }else{
    //不等待,直接返回
    logger.info("====產(chǎn)品已被占用,直接返回====");
    return flag;
   }
  }else{
   logger.info("====產(chǎn)品未被占用,添加同步鎖====");
   flag = false;
   keyList.add(key);
  }
  return flag;
 }
 /**
  * 在緩存中查詢key是否存在
  * 若存在則返回true;
  * 若不存在則將key放入緩存,設(shè)置過(guò)期時(shí)間,返回false
  * @param key
  * @param keyTimeout key超時(shí)時(shí)間單位是秒
  * @return
  */
 boolean isLockedInRedis(String key,int keyTimeout){
  logger.info("====在緩存中查詢key是否存在====");
  boolean isExist = false;
  //與redis交互,查詢對(duì)象是否上鎖
  Long result = this.redisClientTemplate.setnx(key, uuid);
  logger.info("====上鎖 result = "+result+"====");
  if(null != result  1 == Integer.parseInt(result.toString())){
   logger.info("====設(shè)置緩存失效時(shí)長(zhǎng) = "+keyTimeout+"秒====");
   this.redisClientTemplate.expire(key, keyTimeout);
   logger.info("====上鎖成功====");
   isExist = false;
  }else{
   logger.info("====上鎖失敗====");
   isExist = true;
  }
  return isExist;
 }
 /**
  * 根據(jù)傳入key,對(duì)該產(chǎn)品進(jìn)行解鎖
  * @param key
  * @return
  */
 public void unlock(){
  //與redis交互,對(duì)產(chǎn)品解鎖
  if(keyList.size()>0){
   for(String key : this.keyList){
    String value = this.redisClientTemplate.get(key);
    if(null != value  !"".equals(value)){
     if(uuid.equals(value)){
      logger.info("====解鎖key:"+key+" value="+value+"====");
      this.redisClientTemplate.del(key);
     }else{
      logger.info("====待解鎖集合中key:"+key+" value="+value+"與uuid不匹配====");
     }
    }else{
     logger.info("====待解鎖集合中key="+key+"的value為空====");
    }
   }
  }else{
   logger.info("====待解鎖集合為空====");
  }
 }
}

2.2、業(yè)務(wù)調(diào)用模擬樣例

//獲取同步鎖工具類
  SynchrolockUtil synchrolockUtil = SpringUtils.getBean("synchrolockUtil");
  //獲取需上鎖資源的KEY
  String key = "abc";
  //查詢是否上鎖,上鎖輪詢,未上鎖加鎖
  boolean isLocked = synchrolockUtil.islocked(key,synchrolockUtil.RETRYTYPE_WAIT);
  //判斷上鎖結(jié)果
  if(isLocked){
   logger.error("同步鎖請(qǐng)求超時(shí)并返回 key ="+key);
  }else{
   logger.info("====同步鎖加鎖陳功====");
  }
  try {
   //執(zhí)行業(yè)務(wù)處理
  } catch (Exception e) {
   logger.error("業(yè)務(wù)異常:"+e.getMessage(), e);
  }finally{
   //解鎖
    synchrolockUtil.unlock();
  }

2.3、如果業(yè)務(wù)處理內(nèi)部,還有嵌套加鎖需求,只需將對(duì)象傳入方法內(nèi)部,加鎖成功后將key值追加到集合中即可

ps:實(shí)際實(shí)現(xiàn)中還需要jedis工具類,需額外添加調(diào)用

補(bǔ)充:使用redis鎖還是出現(xiàn)同步問題

一種可能是,2臺(tái)機(jī)器同時(shí)訪問,一臺(tái)訪問,還沒有把鎖設(shè)置過(guò)去的時(shí)候,另一臺(tái)也查不到就會(huì)出現(xiàn)這個(gè)問題。

解決方法

這我跟寫代碼的方式有關(guān)。先查,如果不存在就set,這種方式有極微小的可能存在時(shí)間差,導(dǎo)致鎖set了2次。

推薦使用setIfAbsent 這樣在redis set的時(shí)候是單線程的。不會(huì)存在重復(fù)的問題。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Redis的主從同步解析
  • 簡(jiǎn)單注解實(shí)現(xiàn)集群同步鎖(spring+redis+注解)
  • SpringBoot集成redis實(shí)現(xiàn)分布式鎖的示例代碼
  • 基于redis setIfAbsent的使用說(shuō)明
  • Redis實(shí)現(xiàn)分布式Session管理的機(jī)制詳解
  • kubernetes環(huán)境部署單節(jié)點(diǎn)redis數(shù)據(jù)庫(kù)的方法

標(biāo)簽:果洛 臺(tái)州 朝陽(yáng) 江蘇 大慶 北京 楊凌 吉安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Redis 實(shí)現(xiàn)同步鎖案例》,本文關(guān)鍵詞  Redis,實(shí)現(xiàn),同步,鎖,案例,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Redis 實(shí)現(xiàn)同步鎖案例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Redis 實(shí)現(xiàn)同步鎖案例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    国语对白做受69按摩| 都市激情久久久久久久久久久| 宅男在线一区| 人人妻人人澡人人爽久久av| 青青草免费在线视频观看| 国产黄色免费网站| www.天天干.com| 97精品国产97久久久久久免费| 在线视频欧美区| 久久99精品波多结衣一区| 亚洲精品无码专区在线播放| 欧美精品手机在线| 无人区在线高清完整免费版 一区二| 国产99久久久国产精品潘金网站| 日韩精品免费| 午夜视频在线观看一区| 免费xxxx性欧美18vr| 综合久久一本| 国产aⅴ精品一区二区三区久久| 中文字幕二三区不卡| 国产视频在线视频| 欧美一级黄色带| 午夜精品久久久久久毛片| 亚洲高清免费视频| 欧美天堂社区| 一区二区三区在线视频观看58| 毛片网站在线观看| 久久亚洲天堂网| 欧美性videos高清精品| 无码人妻精品中文字幕| 一区二区三区国产好的精华液| 中文字幕人妻一区二区三区在线视频| 深夜福利视频网站| 小舞被吸乳羞羞网站视频| 欧美一级视频在线播放| 在线看片黄色| 亚洲一级毛片| 一级黄色片毛片| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美大片日本大片免费观看| 五月天激情开心网| 欧美成人全部免费| 国产一区二区三区在线看| 免费a级毛片在线播放| 在线视频2区| 五月婷婷久久综合| 久久久久天天天天| 懂色av影视一区二区三区| 一级毛片久久久| 看成年女人免费午夜视频| 国产午夜精品无码一区二区| 91久久国产综合久久91猫猫| 福利在线观看| 日韩欧美黄色动漫| 国产精品伦理在线| 成人h动漫精品一区二区| 日韩成人精品一区二区三区| 欧美性猛交xxxx免费看漫画| 成人免费视频毛片| yellow在线观看网址| 亚洲第一网中文字幕| 色视频免费版高清在线观看| 亚洲国产精品久久艾草纯爱| 日本特黄一级片| 一区二区91| 久久久久久久黄色| 国产精品19p| 91视频成人| 成人a级免费视频| 丝袜美腿亚洲一区| jizzjizzjizzjizz| 亚洲卡一卡二卡三| 人妻体内射精一区二区三区| 综合另类专区| 一区二区三区中文在线| 国产视频一区二区在线观看| 国产丝袜控视频在线观看| 欧美精品乱码久久久久久| 亚洲精品伦理在线| 中文字幕av久久爽| 日本电影全部在线观看网站视频| 亚洲的天堂在线中文字幕| 欧美高清视频在线观看| 国产乡下妇女做爰毛片| 日韩精品三级| 国产精品自拍亚洲| 日本一二区免费| 亚洲一区不卡在线| av7777777| 日韩欧美自拍偷拍| 中文字幕av网址| 久久理论电影| 日韩电影免费在线观看| 日韩av片免费在线观看| 91av一区二区三区| yw193.com尤物在线| 乱插在线www| 日韩三级影视| 亚洲第一精品网站| 性欧美videos| 亚洲色图17p| 亚洲精品成人少妇| 欧美在线观看一区二区| 色婷婷狠狠18禁久久| 亚洲成av人片在线观看| 人妻无码中文字幕免费视频蜜桃| 玖玖精品一区| 自拍日韩欧美| 亚洲一级二级片| 污视频在线播放| 亚洲大胆人体av| 美女航空一级毛片在线播放| av在线天天| 操bbb操bbb| 久久精品久久久| 免费在线一区观看| 色老综合老女人久久久| 最新中文字幕久久| 毛片毛片毛片毛片毛片毛片毛片毛片毛片| 电影一区二区| 老熟妻内射精品一区| 国产精品伦一区二区三区| 女人公敌韩国| 91看片免费| 国产乱妇无码大片在线观看| 激情都市亚洲| 日韩经典一区| 日韩午夜精品| 久久久亚洲天堂| 欧美日韩精品一本二本三本| 理论不卡电影大全神| 精品久久久久久亚洲| 精品88久久久久88久久久| 国产精品―色哟哟| 日韩亚洲视频在线| 免费观看成人高潮| 久久国产情侣| 日欧美一区二区| 国产精品成人在线观看| 国产模特精品视频久久久久| www.美色吧.com| 欧美视频精品全部免费观看| 日韩中文字幕区一区有砖一区| 欧美精品成人在线| 亚洲高清视频在线播放| eeuss国产一区二区三区| 亚洲国产日韩欧美一区二区三区| 一级黄色录像视频| 美女av免费观看| 国产精品久久九九| 国产日韩视频一区| 国产一区二区三区高清| 欧美精品色一区二区三区| 在线免费a视频| 国产美女精品久久| av在线网址导航| av直播在线观看| av噜噜在线观看| 欧美亚洲激情在线| 日韩一区欧美小说| 在线电影中文日韩| 久久99精品久久久久久久青青日本| 亚洲一区二区三区欧美| 疯狂揉花蒂控制高潮h| 亚洲一二三四在线| 丁香五月网久久综合| 亚洲男女网站| 久久亚洲精选| 99久热在线精品996热是什么| 国产精品三级久久久久三级| 日韩在线你懂的| 亚洲综合一二区| 欧美激情视频网| 亚洲av无一区二区三区| 成人免费毛片网| 国产真实乱人偷精品| 99久久婷婷国产综合精品| 欧美性色aⅴ视频一区日韩精品| 81精品国产乱码久久久久久| 在线观看国产一区二区| 91亚洲永久免费精品| 老司机午夜av| 日本中文字幕电影| 成人无码精品1区2区3区免费看| 成人爽a毛片一区二区| 热久久一区二区| 在线播放中文字幕一区| 俄罗斯嫩小性bbwbbw| 一区二区视频| 久久国产精品高清一区二区三区| 国产黄色小视频在线| 日日夜夜精品视频免费| 色香色香欲天天天影视综合网| 国产精品成人a在线观看| 欧美一区二区三区四区高清| 日本免费一区二区三区最新| 不卡av电影在线播放| 福利网站av| 黄色在线视频网| 亚洲国产日韩精品在线| www.99re.av| 日韩三级电影网| 色一情一乱一区二区三区| 黄色不卡一区| 亚洲熟妇无码av在线播放| 亚洲国产日韩精品在线| 免费黄色av电影| 欧美在线视频a| 色哟哟在线观看| 成人免费看吃奶视频网站| 在线日韩成人| 在线观看一区二区三区视频| 这里只有精品电影| 国产亚洲一卡2卡3卡4卡新区| 蜜桃a∨噜噜一区二区三区| 日韩伦理在线视频| 亚洲成av人片在线| 中文字幕伦av一区二区邻居| youjizz亚洲女人| 日韩极品在线观看| 免费看国产精品一二区视频| 国产精品久久久久9999赢消| 国产农村妇女精品一区| 国产亚洲精aa在线看| 免费一级在线观看播放网址| 久久久久一区二区三区四区| 37pao成人国产永久免费视频| 亚洲影视一区| 日韩中文字幕精品视频| 日本www在线| 欧美大胆成人| 成人自拍av| 国产精品一区二区av| 久草视频在线资源| 日本丰满www色| 欧美日韩第一视频| 首页亚洲中字| 久久精品成人欧美大片| 国产精品99精品| 九色porny丨入口在线| 影视一区二区三区| 日韩美女在线视频| 男女男精品视频网站| 青青草成人网| 色综合视频一区中文字幕| 亚洲人成无码网站久久99热国产| 久久久999精品视频| 亚洲福利视频一区二区| 91九色在线免费视频| 农民人伦一区二区三区| 精品久久久久国产| 亚洲免费视频中文字幕| 日本全棵写真视频在线观看| av免费在线一区二区三区| 国产三区二区一区久久| 最近的中文字幕在线看视频| 国产精品精品视频一区二区三区| 刘亦菲久久免费一区二区| 深夜福利网站| 国产亚洲精品超碰| 国产成人免费看一级大黄| 亚洲男人的天堂网| 欧美老女人在线| 男人天堂新网址| 亚洲精品第五页| 日韩亚洲欧美中文字幕| 加勒比综合在线| 亚洲高清色综合| wwwxxx国产| 欧美高清hd18日本| 9i看片成人免费高清| 成年人小视频在线观看| 日韩欧美在线中文字幕| 一区二区三区视频播放| www.国产精品视频| 欧美伊人久久大香线蕉综合69| 少妇精品高潮欲妇又嫩中文字幕| 北岛玲一区二区三区| 国产又黄又猛的视频| 91精品国产高清91久久久久久| 天堂а√在线8种子蜜桃视频| 欧美一卡2卡三卡4卡5免费| 日本在线视频观看| 久久躁日日躁aaaaxxxx| 国产欧美啪啪| 少妇av一区二区三区无码| 亚洲三级免费电影| 日韩成人网免费视频| 跑男十一季在线观看免费| 高潮一区二区三区乱码| 欧美日韩一区二区区| 国产日韩欧美一区二区三区在线观看| 成人毛片视频在线观看| 国产又粗又猛又爽又黄的视频四季| 亚洲第一区第二区| 久久久久久久免费视频| 大陆极品少妇内射aaaaaa| 99在线视频播放| 国产成人免费高清| 欧美电影三区| 色涩成人影视在线播放| 国产91对白刺激露脸在线观看| 91天堂素人约啪| 亚洲国产精品字幕| 亚洲 欧美综合在线网络| 亚洲国产美女搞黄色| 久久精品日产第一区二区三区乱码| 波多野结衣家庭主妇| 欧美日韩激情在线观看| 日本不卡免费一区| 8av国产精品爽爽ⅴa在线观看| 日本不卡一区二区三区| 久久久久久久欧美精品| 久久国内精品自在自线400部| 国产亚洲综合性久久久影院| 色视频在线免费观看| 欧美伊人久久久久久久久影院| 亚洲大片在线观看| 欧美精品www在线观看| 午夜精品亚洲| 中文岛国精品亚洲一区| 亚洲成人资源在线| 激情综合网av| 无码人妻久久一区二区三区| 亚洲欧美自拍另类日韩| 欧美韩日一区二区三区| 欧美片一区二区| 女人被男人躁得好爽免费视频|