亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 詳解利用redis + lua解決搶紅包高并發的問題

詳解利用redis + lua解決搶紅包高并發的問題

熱門標簽:小紅書怎么地圖標注店 太原營銷外呼系統 最簡單的百度地圖標注 玄武湖地圖標注 竹間科技AI電銷機器人 地圖標注費用 西藏教育智能外呼系統價格 地圖標注如何即時生效 百度商家地圖標注怎么做

搶紅包的需求分析

搶紅包的場景有點像秒殺,但是要比秒殺簡單點。

因為秒殺通常要和庫存相關。而搶紅包則可以允許有些紅包沒有被搶到,因為發紅包的人不會有損失,沒搶完的錢再退回給發紅包的人即可。

另外像小米這樣的搶購也要比淘寶的要簡單,也是因為像小米這樣是一個公司的,如果有少量沒有搶到,則下次再搶,人工修復下數據是很簡單的事。而像淘寶這么多商品,要是每一個都存在著修復數據的風險,那如果出故障了則很麻煩。

基于redis的搶紅包方案

下面介紹一種基于Redis的搶紅包方案。

把原始的紅包稱為大紅包,拆分后的紅包稱為小紅包。

1.小紅包預先生成,插到數據庫里,紅包對應的用戶ID是null。生成算法見另一篇文章:https://www.jb51.net/article/98620.htm

2.每個大紅包對應兩個redis隊列,一個是未消費紅包隊列,另一個是已消費紅包隊列。開始時,把未搶的小紅包全放到未消費紅包隊列里。

未消費紅包隊列里是json字符串,如{userId:'789', money:'300'}。

3.在redis中用一個map來過濾已搶到紅包的用戶。

4.搶紅包時,先判斷用戶是否搶過紅包,如果沒有,則從未消費紅包隊列中取出一個小紅包,再push到另一個已消費隊列中,最后把用戶ID放入去重的map中。

5.用一個單線程批量把已消費隊列里的紅包取出來,再批量update紅包的用戶ID到數據庫里。

上面的流程是很清楚的,但是在第4步時,如果是用戶快速點了兩次,或者開了兩個瀏覽器來搶紅包,會不會有可能用戶搶到了兩個紅包?

為了解決這個問題,采用了lua腳本方式,讓第4步整個過程是原子性地執行。

下面是在redis上執行的Lua腳本:

-- 函數:嘗試獲得紅包,如果成功,則返回json字符串,如果不成功,則返回空 
-- 參數:紅包隊列名, 已消費的隊列名,去重的Map名,用戶ID 
-- 返回值:nil 或者 json字符串,包含用戶ID:userId,紅包ID:id,紅包金額:money 
 
-- 如果用戶已搶過紅包,則返回nil 
if rediscall('hexists', KEYS[3], KEYS[4]) ~= 0 then 
 return nil 
else 
 -- 先取出一個小紅包 
 local hongBao = rediscall('rpop', KEYS[1]); 
 if hongBao then 
  local x = cjsondecode(hongBao); 
  -- 加入用戶ID信息 
  x['userId'] = KEYS[4]; 
  local re = cjsonencode(x); 
  -- 把用戶ID放到去重的set里 
  rediscall('hset', KEYS[3], KEYS[4], KEYS[4]); 
  -- 把紅包放到已消費隊列里 
  rediscall('lpush', KEYS[2], re); 
  return re; 
 end 
end 
return nil 

下面是測試代碼:

public class TestEval { 
  static String host = "localhost"; 
  static int honBaoCount = 1_0_0000; 
   
  static int threadCount = 20; 
   
  static String hongBaoList = "hongBaoList"; 
  static String hongBaoConsumedList = "hongBaoConsumedList"; 
  static String hongBaoConsumedMap = "hongBaoConsumedMap"; 
   
  static Random random = new Random(); 
   
// -- 函數:嘗試獲得紅包,如果成功,則返回json字符串,如果不成功,則返回空 
// -- 參數:紅包隊列名, 已消費的隊列名,去重的Map名,用戶ID 
// -- 返回值:nil 或者 json字符串,包含用戶ID:userId,紅包ID:id,紅包金額:money 
  static String tryGetHongBaoScript =  
//     "local bConsumed = rediscall('hexists', KEYS[3], KEYS[4]);\n" 
//     + "print('bConsumed:' ,bConsumed);\n" 
      "if rediscall('hexists', KEYS[3], KEYS[4]) ~= 0 then\n" 
      + "return nil\n" 
      + "else\n" 
      + "local hongBao = rediscall('rpop', KEYS[1]);\n" 
//     + "print('hongBao:', hongBao);\n" 
      + "if hongBao then\n" 
      + "local x = cjsondecode(hongBao);\n" 
      + "x['userId'] = KEYS[4];\n" 
      + "local re = cjsonencode(x);\n" 
      + "rediscall('hset', KEYS[3], KEYS[4], KEYS[4]);\n" 
      + "rediscall('lpush', KEYS[2], re);\n" 
      + "return re;\n" 
      + "end\n" 
      + "end\n" 
      + "return nil"; 
  static StopWatch watch = new StopWatch(); 
   
  public static void main(String[] args) throws InterruptedException { 
//   testEval(); 
    generateTestData(); 
    testTryGetHongBao(); 
  } 
   
  static public void generateTestData() throws InterruptedException { 
    Jedis jedis = new Jedis(host); 
    jedisflushAll(); 
    final CountDownLatch latch = new CountDownLatch(threadCount); 
    for(int i = 0; i  threadCount; ++i) { 
      final int temp = i; 
      Thread thread = new Thread() { 
        public void run() { 
          Jedis jedis = new Jedis(host); 
          int per = honBaoCount/threadCount; 
          JSONObject object = new JSONObject(); 
          for(int j = temp * per; j  (temp+1) * per; j++) { 
            objectput("id", j); 
            objectput("money", j); 
            jedislpush(hongBaoList, objecttoJSONString()); 
          } 
          latchcountDown(); 
        } 
      }; 
      threadstart(); 
    } 
    latchawait(); 
  } 
   
  static public void testTryGetHongBao() throws InterruptedException { 
    final CountDownLatch latch = new CountDownLatch(threadCount); 
    Systemerrprintln("start:" + SystemcurrentTimeMillis()/1000); 
    watchstart(); 
    for(int i = 0; i  threadCount; ++i) { 
      final int temp = i; 
      Thread thread = new Thread() { 
        public void run() { 
          Jedis jedis = new Jedis(host); 
          String sha = jedisscriptLoad(tryGetHongBaoScript); 
          int j = honBaoCount/threadCount * temp; 
          while(true) { 
            Object object = jediseval(tryGetHongBaoScript, 4, hongBaoList, hongBaoConsumedList, hongBaoConsumedMap, "" + j); 
            j++; 
            if (object != null) { 
//             Systemoutprintln("get hongBao:" + object); 
            }else { 
              //已經取完了 
              if(jedisllen(hongBaoList) == 0) 
                break; 
            } 
          } 
          latchcountDown(); 
        } 
      }; 
      threadstart(); 
    } 
     
    latchawait(); 
    watchstop(); 
     
    Systemerrprintln("time:" + watchgetTotalTimeSeconds()); 
    Systemerrprintln("speed:" + honBaoCount/watchgetTotalTimeSeconds()); 
    Systemerrprintln("end:" + SystemcurrentTimeMillis()/1000); 
  } 
} 

測試結果20個線程,每秒可以搶2.5萬個,足以應付絕大部分的搶紅包場景。

如果是真的應付不了,拆分到幾個redis集群里,或者改為批量搶紅包,也足夠應付。

總結:

redis的搶紅包方案,雖然在極端情況下(即redis掛掉)會丟失一秒的數據,但是卻是一個擴展性很強,足以應付高并發的搶紅包方案。

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

您可能感興趣的文章:
  • Nginx+Lua+Redis構建高并發Web應用
  • Redis實現高并發計數器
  • 如何利用Redis鎖解決高并發問題詳解
  • Redis瞬時高并發秒殺方案總結
  • PHP實現Redis單據鎖以及防止并發重復寫入
  • jedispool連redis高并發卡死的問題
  • 使用lua+redis解決發多張券的并發問題

標簽:澳門 唐山 林芝 揚州 香港 景德鎮 廣東 贛州

巨人網絡通訊聲明:本文標題《詳解利用redis + lua解決搶紅包高并發的問題》,本文關鍵詞  詳解,利用,redis,lua,解決,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解利用redis + lua解決搶紅包高并發的問題》相關的同類信息!
  • 本頁收集關于詳解利用redis + lua解決搶紅包高并發的問題的相關信息資訊供網民參考!
  • 推薦文章
    久久福利影视| 一级女性大黄生活片免费| 日韩欧美一二三区| 欧美1卡一卡二卡三新区| 99热精品在线| 黄视频网站免费| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 亚久久伊人精品青青草原2020| 国产一区免费观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 午夜激情视频在线观看| 日本在线www| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 精品久久久久久影院免费| 久草免费资源| 欧美a级片免费看| 久久久成人网| 精品视频在线观看视频免费视频 | 亚洲 国产精品 日韩| 超级乱淫黄漫画免费| 国产一区二区精品在线观看| 91麻豆爱豆果冻天美星空| 欧美电影免费| 精品在线观看一区| 99久久精品费精品国产一区二区| 欧美激情一区二区三区在线| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产国语在线播放视频| 久久99中文字幕| 亚欧成人毛片一区二区三区四区| 国产网站麻豆精品视频| 可以免费看污视频的网站| 九九久久国产精品大片| 欧美另类videosbestsex| 国产高清在线精品一区二区 | 九九干| 国产成人精品在线| 999久久狠狠免费精品| 香蕉视频久久| 日韩av东京社区男人的天堂| 香蕉视频久久| 在线观看导航| 欧美1卡一卡二卡三新区| 精品视频在线看| 国产一区二区精品| 亚洲精品久久久中文字| 黄视频网站免费看| 欧美日本韩国| 亚洲第一页乱| 日韩av成人| 精品久久久久久免费影院| 韩国三级视频网站| 99热精品在线| 国产成人精品影视| 国产视频一区二区三区四区| 国产精品123| 毛片高清| 国产91丝袜高跟系列| 中文字幕一区二区三区精彩视频| 亚洲 男人 天堂| 免费一级片网站| 精品视频在线看| 国产一区二区精品在线观看| 999久久久免费精品国产牛牛| 免费国产在线观看不卡| 国产视频一区二区三区四区| 韩国毛片| 日日爽天天| 麻豆网站在线看| 国产一区二区精品| 精品视频免费在线| 日韩在线观看免费完整版视频| 亚洲 欧美 成人日韩| 一级女性大黄生活片免费| 久久久成人网| 亚洲天堂一区二区三区四区| 可以免费看毛片的网站| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 91麻豆精品国产自产在线 | 青青久久精品| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日日夜夜婷婷| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 欧美激情一区二区三区视频| 欧美大片一区| 国产综合91天堂亚洲国产| 国产不卡福利| 国产成人精品在线| 日日日夜夜操| 国产91精品一区二区| 国产国产人免费视频成69堂| 99久久精品国产高清一区二区 | 久久久成人网| 四虎影视久久久免费| 日韩在线观看网站| 色综合久久天天综合| 久久久久久久免费视频| 欧美日本韩国| 国产成人精品在线| 国产一区免费在线观看| 美国一区二区三区| 久久国产影院| 国产精品自拍亚洲| 国产美女在线一区二区三区| 成人高清视频在线观看| 精品国产亚一区二区三区| 欧美爱爱动态| 国产a网| 四虎久久精品国产| 国产成人啪精品视频免费软件| 天天做日日干| 亚洲精品永久一区| 久久国产精品只做精品| 欧美一区二区三区在线观看| 99久久精品国产麻豆| 国产亚洲精品成人a在线| 国产精品免费久久| 99久久精品国产麻豆| 精品久久久久久影院免费| 亚洲精品久久久中文字| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 精品在线视频播放| 深夜做爰性大片中文| 国产麻豆精品| 久久精品免视看国产明星| 精品国产一级毛片| 国产伦久视频免费观看 视频| 美女免费精品高清毛片在线视| 亚飞与亚基在线观看| 美女免费精品视频在线观看| 欧美另类videosbestsex视频| 国产一区二区精品久久| 夜夜操网| 99热热久久| 日韩在线观看视频黄| 国产国产人免费视频成69堂| 99久久精品费精品国产一区二区| 韩国毛片| 欧美国产日韩在线| 99久久精品费精品国产一区二区| 高清一级做a爱过程不卡视频| 青青青草影院| 日本乱中文字幕系列| 欧美一级视| 九九干| 久久国产精品自由自在| 精品久久久久久中文| 成人av在线播放| 日韩在线观看网站| 天天做人人爱夜夜爽2020| 在线观看导航| 一级毛片视频免费| 九九九国产| 亚洲精品影院| 精品视频免费在线| 99久久精品国产免费| 欧美爱色| 麻豆系列国产剧在线观看| 国产伦久视频免费观看视频| 免费国产在线观看| 欧美激情一区二区三区中文字幕| 国产激情一区二区三区| 中文字幕一区二区三区 精品| 欧美激情影院| 日韩欧美一二三区| 成人免费网站久久久| 日韩在线观看免费完整版视频| 成人免费一级纶理片| 99久久精品国产国产毛片 | 日韩中文字幕在线观看视频| 欧美另类videosbestsex高清| 亚欧成人毛片一区二区三区四区| 一级片片| 久久久久久久网| 韩国毛片| 韩国毛片| 国产一区二区高清视频| 国产视频一区二区三区四区| 欧美电影免费看大全| 日本在线不卡视频| 国产综合成人观看在线| 日本特黄特色aaa大片免费| 亚州视频一区二区| 亚欧视频在线| 国产欧美精品| 日韩一级黄色| 色综合久久天天综合绕观看| 日本免费看视频| 天堂网中文字幕| 九九国产| 91麻豆精品国产自产在线 | 国产成人精品一区二区视频| 亚欧成人乱码一区二区| 成人免费一级纶理片| 中文字幕97| 国产伦精品一区二区三区在线观看| 国产a免费观看| 国产一区二区精品| 青青青草影院| 色综合久久天天综合绕观看|