日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

node.js - 抽獎碼設計問題

瀏覽:225日期:2022-06-19 17:28:32

問題描述

程序的邏輯:

程序事先生成了抽獎碼存在mysql中,然后有用戶來的以后,找到一個沒有用過的抽獎碼給他,然后把這個抽獎碼設置成為已經使用過了

問題:當大量用戶同時并發請求的時候,大部分用戶返回同一個抽獎碼

原因大概是這樣子的

select codeid,codevalue from tb_code where isused=0 Limit 1

通過上面的sql找到一個沒有使用過的抽獎碼

update tb_code set isused=1 where codeid=codeid

然后上面的sql語句是更新為已經使用

當大量用過過來的時候,比如A先取到一個碼XYBV,但是還沒有更新,B用戶也過來了的時候找到的也是這個碼值了。

code的返回都是在執行完update以后返回

后來修改了下更新語句

update tb_code set isused=1 where isused=0 and codeid=codeid

根據affectedRows來判斷是不是更新成功了,如果成功的話,則返回code,否返回一個null

這樣雖然不會返回重復的值,但是會有一部分收不到碼值

再后來的搜了下,使用直接更新查找到碼值,最后再通過ranomno來查找剛才更新的碼值,如下面所示的sql

update tb_code set isused=1,randomno=’+randomno+’ where codeid in ( select codeid from (select codeid from tb_code where isused=0 Limit 1) as arbitraryTableName)’;

剛開始本地測試的時候,沒有問題,想著解決了。后來上線,檢測日志的時候,發現很多請求長時間沒有響應,應該是上面的sql語句執行的效率太低了。

最后換了一種方法使用redis緩存code

先從庫里面取1000個code使用Lpush放去redis里面去,然后當用戶有請求過來,直接從redis里面取Rpop

然后做一個定時任務,檢測redis里面的code數量,如果少于設定的數量,就從庫里面取1000個Lpush到redis里面去

現在項目跑了幾個小時,暫時沒有發現請求超時的問題和碼值重復的問題。

但是感覺這種方式湊合能用,但不是最好的

想請問大家,對于類似的問題有沒有最佳實踐,比如在數據庫設計和程序結構上

問題解答

回答1:

你可以事先生成所有的code,放redis里,這樣不用一千一千的再去弄了。

你也可以用mongodb,查詢修改數據庫并發性能也挺強的;

回答2:

可以試試mysql 的事務呢?http://dwz.cn/3SrgGk

回答3:

抽獎碼即時根據uid算一個 加一點隨機字符串

相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
视频一区中文| 日韩精品91亚洲二区在线观看| 水蜜桃久久夜色精品一区的特点| 欧美精品成人| 亚洲久草在线| 国产精品久久久久久久久久久久久久久 | 激情六月综合| 久久精品一区二区国产| 亚洲97av| 一级欧美视频| 在线精品视频一区| 欧美精选视频一区二区| 国产福利电影在线播放| 中文不卡在线| 国精品一区二区三区| 日韩国产在线| 久久久久久久久久久妇女| 黑森林国产精品av| 久久精品三级| 国产欧美激情| 国产一区调教| 国产精品亚洲一区二区三区在线观看| 久久电影tv| 亚洲不卡系列| 五月婷婷六月综合| 亚洲在线成人| 免费看精品久久片| 日韩一区二区在线免费| 999视频精品| 好吊视频一区二区三区四区| 欧美69视频| 一区二区国产在线观看| 亚洲va久久久噜噜噜久久| av一区二区高清| 日本不卡高清| 亚洲黄色免费av| 91精品蜜臀一区二区三区在线 | 久久大逼视频| 久久久精品久久久久久96| av不卡免费看| 国产剧情一区二区在线观看| 国产精品极品| 国产麻豆久久| 视频在线观看国产精品| 欧美二区视频| 亚洲人成网77777色在线播放| 亚洲性视频在线| 国产精品久久久久久妇女| 你懂的网址国产 欧美| 婷婷亚洲五月| 精品淫伦v久久水蜜桃| 日韩大片免费观看| 欧美日韩在线二区| 国产毛片精品久久| 亚洲女同一区| 大香伊人久久精品一区二区| 午夜国产精品视频| 国产一区二区三区四区五区| 精品三级在线| 亚洲激情黄色| 国产精品www994| 激情婷婷综合| 日本久久精品| 日韩高清国产一区在线| 婷婷综合社区| 蜜臀久久久99精品久久久久久| 国产毛片精品久久| 视频在线观看一区二区三区| 97精品一区二区| 国产伦精品一区二区三区在线播放| 日韩在线观看一区二区三区| 亚洲一级黄色| av免费不卡国产观看| 久久精品国产99久久| 精品香蕉视频| 激情综合五月| 国产视频一区二| 欧美激情福利| 91亚洲无吗| 国产亚洲人成a在线v网站| 亚洲一级大片| 久久美女性网| 日韩在线观看| 91tv亚洲精品香蕉国产一区| 中文字幕在线视频久| 日韩大片免费观看| 精品一区欧美| 蜜芽一区二区三区| 午夜在线精品| 日韩精品一区二区三区中文在线| 日韩三级精品| 国产精品黄色片| 亚洲不卡系列| 日韩精品一卡二卡三卡四卡无卡| 午夜精品亚洲| 三级亚洲高清视频| 蜜桃久久av一区| 精品国产麻豆| 欧美午夜精品一区二区三区电影| 久久精品导航| 水野朝阳av一区二区三区| 亚洲精品亚洲人成在线观看| 日韩精品一区二区三区中文字幕| 亚洲精品激情| 成人精品久久| 国产一区久久| 国产亚洲精品美女久久 | 国产v日韩v欧美v| 日韩午夜一区| 免费在线日韩av| 亚洲免费观看| 一区二区国产在线| 日韩国产欧美在线播放| 国产欧美一级| 成午夜精品一区二区三区软件| 91精品啪在线观看国产18| 蜜臀精品一区二区三区在线观看 | 久久亚洲人体| 丝袜a∨在线一区二区三区不卡| 国产精品亚洲综合久久| 另类中文字幕国产精品| 欧美另类中文字幕| 欧美精品aa| 国模精品一区| 亚洲免费一区二区| 久久狠狠婷婷| 国产精品日本一区二区三区在线| 国产精品一区二区精品 | 日韩动漫一区| 久久国产88| 91九色精品| 欧美13videosex性极品| 欧美激情综合| 欧美永久精品| 国产日韩亚洲| 日韩av一级片| 日韩av一区二区三区四区| 日韩精品看片| 午夜欧美巨大性欧美巨大| 久久精品二区亚洲w码| 国产日产高清欧美一区二区三区| 免费看黄色91| 日日摸夜夜添夜夜添国产精品| 欧美日韩少妇| 丝袜脚交一区二区| 视频一区在线视频| 亚洲精品人人| 日本午夜精品| 国产视频一区二区在线播放| 精品国产亚洲一区二区在线观看| 久久亚洲黄色| 久久青草久久| 国产欧美二区| 婷婷成人在线| 老鸭窝亚洲一区二区三区| 香蕉精品视频在线观看| 91精品蜜臀一区二区三区在线| 国产欧美视频在线| 国产日韩高清一区二区三区在线| 另类国产ts人妖高潮视频| 欧美精品羞羞答答| 久久久久一区| 欧美日韩国产高清| 99成人在线| 在线观看视频免费一区二区三区| 久久亚洲精品伦理| 日本在线成人| 欧美一区激情| 88久久精品| 青青伊人久久| 免费人成在线不卡| 国产另类在线| 欧美一级二级三级视频| 精品国产乱码久久久久久1区2匹 | 亚洲精选av| 黄色网一区二区| 免费在线日韩av| 欧美精品国产| 婷婷综合六月| 精品捆绑调教一区二区三区| 欧美日韩在线二区| 麻豆精品av| 国产精品综合| 精品视频网站| 捆绑调教美女网站视频一区| 精品三级国产| 国产精品夜夜夜| 视频在线观看一区| 老司机精品视频在线播放| 日本成人在线一区| 国产伦精品一区二区三区千人斩| 日韩欧美四区| 国产精品一级在线观看| 国产一区三区在线播放| 99热精品在线| 国产精品xxxav免费视频| 久久99青青| 午夜日韩在线| 日韩一区二区三区在线看| 国精品一区二区三区|