校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識(shí)庫 > redis+mysql+quartz 一種紅包發(fā)送功能的實(shí)現(xiàn)

redis+mysql+quartz 一種紅包發(fā)送功能的實(shí)現(xiàn)

熱門標(biāo)簽:地圖標(biāo)注費(fèi)用 玄武湖地圖標(biāo)注 百度商家地圖標(biāo)注怎么做 太原營銷外呼系統(tǒng) 小紅書怎么地圖標(biāo)注店 地圖標(biāo)注如何即時(shí)生效 竹間科技AI電銷機(jī)器人 最簡單的百度地圖標(biāo)注 西藏教育智能外呼系統(tǒng)價(jià)格

概要:

這篇文章主要是對(duì)半年前開發(fā)的紅包模塊進(jìn)行整理,把其中主要的設(shè)計(jì)思想以及具體的實(shí)現(xiàn)方案進(jìn)行介紹,如有設(shè)計(jì)以及實(shí)現(xiàn)上的缺陷,或是存在漏洞,請(qǐng)大家批評(píng)指正!

紅包功能大家都很熟悉了,那在這里就簡單的對(duì)紅包功能進(jìn)行描述... 

功能描述:紅包業(yè)務(wù)主要的功能包括四部分,分別是紅包發(fā)送,紅包接收,紅包回收,以及紅包記錄查詢。

1)紅包發(fā)送:發(fā)送者賬戶->紅包中間層

2)紅包接收:紅包中間層->接收者賬戶

3)紅包回收:紅包中間層中若存在紅包留存超過24小時(shí),則將其回收,紅包中間層->發(fā)送者賬戶

功能描述大體了解之后,那接下來就是實(shí)現(xiàn)方案了... 

首先給出設(shè)計(jì)流程,這部分將依次對(duì)紅包發(fā)送、紅包接收、紅包回收的流程進(jìn)行分析...

1. 設(shè)計(jì)流程

首先是紅包發(fā)送功能,以群紅包為例,其流程圖如下所示:


圖1 紅包發(fā)送流程圖

首先,采用基于高斯分布的方法,將金額100隨機(jī)的分配成8份,然后將這8份數(shù)據(jù)存入到redis緩存隊(duì)列(list)中,同時(shí)將隊(duì)列的過期時(shí)間設(shè)置成24h;考慮到在搶紅包的時(shí)候會(huì)出現(xiàn)重復(fù)搶的問題,那在這里采用的去除重復(fù)的方案是在redis緩存中維護(hù)一個(gè)已分配集合(set),集合里面存儲(chǔ)的是已經(jīng)接收過紅包的用戶ID;另外,在大量的用戶同時(shí)搶紅包的 情況,出于優(yōu)化方面的考慮,為了起到一定的限流作用,同時(shí)減少對(duì)數(shù)據(jù)庫的訪問壓力(考慮這種情況:一個(gè)時(shí)間段內(nèi),大量的用戶在搶紅包,在紅包已經(jīng)分配完的時(shí)刻之后 到來的請(qǐng)求,會(huì)給數(shù)據(jù)庫帶來一定的訪問壓力),那做法是在redis緩存中維護(hù)一個(gè)紅包已分配完的標(biāo)記(key-value),有0(為分配完)/1(已分配完)兩種狀態(tài),從而起到一定的限流作用。

繼緩存層面之后,接下來是數(shù)據(jù)庫層面,那在MySQL中的紅包發(fā)送表(account_coin_records_user_coin_package_send)中生成一條記錄,同時(shí)呢在把上面經(jīng)高斯分布方法得到的8份金額插入到紅包分配表(account_coin_records_user_coin_package_assign)中,初始化分配標(biāo)記為0(未分配),至此,紅包發(fā)送的整個(gè)流程完成。

然后是紅包接收功能,其流程圖如下所示:


圖2 紅包接收流程圖

紅包接收者發(fā)起請(qǐng)求(請(qǐng)求中包含紅包ID、請(qǐng)求人的用戶ID)去搶紅包,首先需要一系列的驗(yàn)證,這個(gè)驗(yàn)證操作要同時(shí)基于redis緩存以及MySQL數(shù)據(jù)庫中的數(shù)據(jù)進(jìn)行 驗(yàn)證,主要是驗(yàn)證紅包ID對(duì)應(yīng)的紅包是否存在、紅包是否已經(jīng)分配完了、紅包是否已經(jīng)過期了、紅包接收者是否重復(fù)接收紅包等。如果驗(yàn)證通過,那么這個(gè)用戶是允許接收到紅包的,接下來就是賬戶同步(紅包中間層->用戶賬戶,事務(wù)處理),若數(shù)據(jù)庫操作成功,則紅包接收成功,否則失敗,至此,紅包接收整體流程完成。

最后就是紅包回收功能,其流程圖如下所示:


圖3 紅包回收流程圖

紅包回收是采用定時(shí)調(diào)度策略發(fā)起的,時(shí)間間隔為5min不間斷的輪詢?cè)L問MySQL數(shù)據(jù)庫,查詢是否有待回收的紅包(紅包在紅包中間層留存已經(jīng)超過24h,且紅包 未 分配完),若有需要回收的紅包,這個(gè)時(shí)候基于效率方面的考慮,采用多線程方案來進(jìn)行回收操作,每個(gè)紅包對(duì)于一個(gè)線程,策略是:一個(gè)線程,一個(gè)請(qǐng)求,一個(gè)事務(wù)(這 個(gè) 方案只適用于待回收的紅包個(gè)數(shù)不是很多的情況)。(注意:若需要回收的紅包很多,若不斷的申請(qǐng)線程,可能造成內(nèi)存溢出問題,這時(shí)候具體問題具體分析,可以考慮生產(chǎn)者-消費(fèi)者模式);分布式架構(gòu),遠(yuǎn)程調(diào)用,接下來處理紅包回收的服務(wù)器接收到紅包回收請(qǐng)求后,進(jìn)行賬戶同步以及紅包狀態(tài)標(biāo)記(標(biāo)記為已回收),若數(shù)據(jù)庫事務(wù)出現(xiàn)異常,那么事務(wù)回滾,此時(shí),這個(gè)紅包沒有回收成功,只能等待下一個(gè)5min后再次被回收。

到這里,流程基本介紹完了,那接下來介紹一下數(shù)據(jù)模型...

2. 數(shù)據(jù)模型

數(shù)據(jù)庫用的是MySQL。將紅包記錄進(jìn)行持久化存儲(chǔ),用于查詢紅包分配記錄以及后期的歷史記錄查詢。紅包分配的數(shù)據(jù)模型如下圖所示:


圖4 紅包分配數(shù)據(jù)模型

圖4中展示了部分的比較重要的數(shù)據(jù)信息,表之間的關(guān)聯(lián)是靠紅包ID建立起來的,紅包記錄以及狀態(tài)標(biāo)記圖中已經(jīng)標(biāo)識(shí)出來了,就不一一介紹了。

在數(shù)據(jù)庫層面,接收紅包功能存在高并發(fā)問題,那接下來就簡單介紹下是如何處理并發(fā)的...

3. 并發(fā)處理

是如何處理高并發(fā)問題的呢?

分析:

首先,由于紅包的金額存放在redis緩存隊(duì)列中,由于redis是單線程的,那么在獲取紅包的階段不存在并發(fā)問題...

然后,下一步是MySQL數(shù)據(jù)庫一系列的update操作,存在高并發(fā)問題...

最后,是記錄保存,insert操作,也不存在并發(fā)問題...

數(shù)據(jù)庫中update操作,主要應(yīng)用樂觀鎖和X鎖兩種方式來保證數(shù)據(jù)一致性的。

4. 并發(fā)測(cè)試

在一段時(shí)間的并發(fā)測(cè)試中,測(cè)試通過,不會(huì)出現(xiàn)數(shù)據(jù)不一致問題,紅包回收功能也能正常進(jìn)行。

目前在并發(fā)方面,至少支持同一時(shí)刻并發(fā)量為3000的搶紅包操作不會(huì)出現(xiàn)問題。

總結(jié),由于能力以及技術(shù)有限,目前的方案基本適用用戶量不是很大的應(yīng)用場(chǎng)景,后期隨著用戶量的增大,會(huì)進(jìn)一步的進(jìn)行優(yōu)化...

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

您可能感興趣的文章:
  • PHP的Laravel框架結(jié)合MySQL與Redis數(shù)據(jù)庫的使用部署
  • PHP使用redis實(shí)現(xiàn)統(tǒng)計(jì)緩存mysql壓力的方法
  • 從MySQL到Redis的簡單數(shù)據(jù)庫遷移方法
  • CentOS 安裝 PHP5.5+Redis+XDebug+Nginx+MySQL全紀(jì)錄
  • python連接MySQL、MongoDB、Redis、memcache等數(shù)據(jù)庫的方法

標(biāo)簽:澳門 香港 林芝 唐山 廣東 景德鎮(zhèn) 贛州 揚(yáng)州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《redis+mysql+quartz 一種紅包發(fā)送功能的實(shí)現(xiàn)》,本文關(guān)鍵詞  redis+mysql+quartz,一種,紅包,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《redis+mysql+quartz 一種紅包發(fā)送功能的實(shí)現(xiàn)》相關(guān)的同類信息!
  • 本頁收集關(guān)于redis+mysql+quartz 一種紅包發(fā)送功能的實(shí)現(xiàn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    成人激情黄色小说| 日韩免费看网站| 精品噜噜噜噜久久久久久久久试看| 国产网站一区二区| 日韩不卡一二三区| 欧美亚洲一区三区| 亚洲国产高清不卡| 国产精品一区二区在线播放| 欧美精品第一页| 亚洲男同性视频| 成人精品一区二区三区四区| 欧美一级二级在线观看| 亚洲精品五月天| jlzzjlzz欧美大全| 国产精品全国免费观看高清| 极品美女销魂一区二区三区免费| 欧美日韩一区二区三区视频| 亚洲欧美日韩在线| 国产福利不卡视频| 久久伊99综合婷婷久久伊| 国产一区999| 蜜臀av性久久久久蜜臀aⅴ流畅| 日韩欧美亚洲一区二区| 国产成人av电影| 午夜激情综合网| 成人国产精品免费观看视频| 精品国产一区二区国模嫣然| 日日夜夜精品视频天天综合网| 欧美在线观看一二区| 亚洲乱码国产乱码精品精98午夜| 不卡高清视频专区| 日韩毛片一二三区| 色狠狠一区二区三区香蕉| 最新中文字幕一区二区三区| 成人v精品蜜桃久久一区| 国产精品少妇自拍| 99国产精品久久| 亚洲私人黄色宅男| 欧美影视一区在线| 91精品黄色片免费大全| 91一区二区在线| 日韩三级视频在线观看| 午夜精品一区二区三区电影天堂 | 亚洲综合999| 三级欧美韩日大片在线看| 国产精品一区二区久久精品爱涩| 91电影在线观看| 亚洲精品一区二区三区99| 亚洲精品福利视频网站| 成人午夜视频在线观看| 欧美一级高清片| 午夜欧美大尺度福利影院在线看| 国产凹凸在线观看一区二区| 日韩精品一区二区三区视频在线观看| 亚洲美女一区二区三区| 国产美女在线观看一区| 最新热久久免费视频| 丝瓜av网站精品一区二区| 成人精品高清在线| 337p粉嫩大胆色噜噜噜噜亚洲| 天天综合网天天综合色| 欧美亚洲国产一区在线观看网站 | 成人免费毛片a| 久久先锋影音av鲁色资源网| 青青草97国产精品免费观看无弹窗版| 在线免费一区三区| 中文天堂在线一区| 国模套图日韩精品一区二区| 欧美一区在线视频| 五月天久久比比资源色| 欧美日韩一区中文字幕| 亚洲成人在线网站| 在线视频国内自拍亚洲视频| 一区二区在线看| 91高清视频免费看| 精品国产露脸精彩对白| 欧美一级在线观看| 欧美日精品一区视频| 欧美在线三级电影| 亚洲精品亚洲人成人网 | 欧美一区二区三区四区在线观看 | 精品少妇一区二区三区视频免付费| 亚洲欧美日韩精品久久久久| 成人免费看黄yyy456| 国产情人综合久久777777| 激情欧美一区二区| 久久精品人人做人人综合| 国产成a人无v码亚洲福利| 中文字幕av一区二区三区| 99精品视频中文字幕| 亚洲人xxxx| 欧美裸体bbwbbwbbw| 91精品福利视频| 久久99久久精品欧美| 一本到一区二区三区| 国产亲近乱来精品视频| 国内精品自线一区二区三区视频| 精品免费国产二区三区| 成人黄色一级视频| 亚洲成在人线在线播放| 精品999在线播放| 成人av电影在线| 香蕉av福利精品导航| 欧美一区二区三区免费大片| 国产美女视频91| 亚洲激情欧美激情| 欧美va在线播放| 91在线视频观看| 日韩国产在线观看一区| 国产日韩精品视频一区| 欧美日韩另类国产亚洲欧美一级| 久久99精品国产.久久久久久| 一区二区国产视频| 国产91丝袜在线18| 日韩欧美一级在线播放| 精品久久久久久久久久久久久久久| 日韩欧美一区二区免费| 成人美女视频在线看| 亚洲国产另类精品专区| 337p日本欧洲亚洲大胆精品| 色婷婷久久久久swag精品| 韩国三级电影一区二区| 一区二区三区**美女毛片| 国产日韩精品一区| 678五月天丁香亚洲综合网| 国产风韵犹存在线视精品| 一区二区三区成人| 久久久久久久综合日本| 欧美三级乱人伦电影| 成人久久18免费网站麻豆| 久久精品国产亚洲一区二区三区| 亚洲久草在线视频| 国产精品入口麻豆原神| 樱桃视频在线观看一区| 精品久久人人做人人爱| 欧美在线免费视屏| 风间由美一区二区av101| 免费一级欧美片在线观看| 一区二区三区色| 国产精品盗摄一区二区三区| 亚洲精品一线二线三线无人区| 欧美日韩三级视频| 色94色欧美sute亚洲线路一久| 国产精品99精品久久免费| 另类中文字幕网| 日韩精品一卡二卡三卡四卡无卡| 亚洲黄色在线视频| 综合欧美一区二区三区| 国产精品久久久久久久久免费相片| 99精品国产91久久久久久 | 欧美精品一二三区| 欧美日韩一区在线观看| 在线看一区二区| 在线观看免费亚洲| 在线看日本不卡| 欧美日韩综合在线免费观看| 欧美日韩综合在线| 欧美亚洲国产一区在线观看网站| 色婷婷综合久久| 色综合视频在线观看| 色8久久精品久久久久久蜜| 99v久久综合狠狠综合久久| 波多野结衣欧美| 91久久精品一区二区| 91久久线看在观草草青青| 欧美性受xxxx黑人xyx性爽| 精品视频一区 二区 三区| 日韩一区二区免费视频| 久久久久高清精品| 国产精品国产三级国产aⅴ无密码| 日韩一区有码在线| 午夜私人影院久久久久| 全国精品久久少妇| 国产成人日日夜夜| 色综合天天天天做夜夜夜夜做| 日本丰满少妇一区二区三区| 欧美丝袜第三区| 日韩女优电影在线观看| 亚洲国产经典视频| 亚洲国产成人tv| 国产乱对白刺激视频不卡| 成人激情小说网站| 欧日韩精品视频| 精品日韩在线观看| 亚洲欧洲成人精品av97| 午夜精品久久久久久久久久| 精品一区二区三区免费视频| 成人免费观看视频| 337p亚洲精品色噜噜| 国产精品天干天干在观线| 午夜私人影院久久久久| 粉嫩13p一区二区三区| 欧美视频一区二区三区| 久久久久国产一区二区三区四区 | 亚洲乱码国产乱码精品精小说 | 亚洲精品一区二区三区精华液| 国产精品国产三级国产三级人妇 | 国产精品一区二区在线观看不卡| 色999日韩国产欧美一区二区| 26uuu亚洲综合色欧美|