色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

node.js - 抽獎碼設計問題

瀏覽:133日期: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算一個 加一點隨機字符串

相關文章:
主站蜘蛛池模板: 亚洲精品一区二区三区福利 | 国产三香港三韩国三级不卡 | 成人精品视频在线观看播放 | 成人a毛片在线看免费全部播放 | 亚洲人免费视频 | 欧美日韩精品在线播放 | 国产黄色三级三级三级 | 欧美黄视频网站 | 正在播放的国产a一片 | 国产人成午夜免费噼啪视频 | 成人国产在线不卡视频 | 久久精品综合免费观看 | 欧美一级毛片欧美一级成人毛片 | 日韩欧美视频一区二区三区 | 久久狠狠一本精品综合网 | 亚州视频一区二区 | 久草视频手机在线观看 | 精品玖玖玖视频在线观看 | 男人躁女人躁的好爽免费视频 | 欧美日韩乱国产 | 国产成a人片在线观看视频 国产成版人视频网站免费下 | 成人国产网站 | 亚洲欧洲视频在线 | 欧美第一页草草影院浮力 | 福利视频美女国产精品 | 毛片久久| 高清视频 一区二区三区四区 | 成人在线视频一区 | 色一情一乱一乱91av | 成人黄色免费网站 | 久久久久视频精品网 | 亚洲综合免费视频 | 欧美人在线一区二区三区 | 国产欧美日韩高清专区手机版 | 日韩午夜免费视频 | 日韩三级视频在线观看 | 国产在线成人精品 | 一区二区三区在线播放视频 | 国产日韩亚洲欧美 | 精品欧美一区视频在线观看 | 免费观看一级特黄三大片视频 |