婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > redis+mysql+quartz 一種紅包發送功能的實現

redis+mysql+quartz 一種紅包發送功能的實現

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

概要:

這篇文章主要是對半年前開發的紅包模塊進行整理,把其中主要的設計思想以及具體的實現方案進行介紹,如有設計以及實現上的缺陷,或是存在漏洞,請大家批評指正!

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

功能描述:紅包業務主要的功能包括四部分,分別是紅包發送,紅包接收,紅包回收,以及紅包記錄查詢。

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

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

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

功能描述大體了解之后,那接下來就是實現方案了... 

首先給出設計流程,這部分將依次對紅包發送、紅包接收、紅包回收的流程進行分析...

1. 設計流程

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


圖1 紅包發送流程圖

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

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

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


圖2 紅包接收流程圖

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

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


圖3 紅包回收流程圖

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

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

2. 數據模型

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


圖4 紅包分配數據模型

圖4中展示了部分的比較重要的數據信息,表之間的關聯是靠紅包ID建立起來的,紅包記錄以及狀態標記圖中已經標識出來了,就不一一介紹了。

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

3. 并發處理

是如何處理高并發問題的呢?

分析:

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

然后,下一步是MySQL數據庫一系列的update操作,存在高并發問題...

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

數據庫中update操作,主要應用樂觀鎖和X鎖兩種方式來保證數據一致性的。

4. 并發測試

在一段時間的并發測試中,測試通過,不會出現數據不一致問題,紅包回收功能也能正常進行。

目前在并發方面,至少支持同一時刻并發量為3000的搶紅包操作不會出現問題。

總結,由于能力以及技術有限,目前的方案基本適用用戶量不是很大的應用場景,后期隨著用戶量的增大,會進一步的進行優化...

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

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

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

巨人網絡通訊聲明:本文標題《redis+mysql+quartz 一種紅包發送功能的實現》,本文關鍵詞  redis+mysql+quartz,一種,紅包,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《redis+mysql+quartz 一種紅包發送功能的實現》相關的同類信息!
  • 本頁收集關于redis+mysql+quartz 一種紅包發送功能的實現的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    在线观看91视频| 最新日韩av在线| 在线不卡a资源高清| 亚洲欧洲99久久| 国产很黄免费观看久久| 日韩欧美一级精品久久| 一区二区在线看| 国产乱理伦片在线观看夜一区| 欧美日韩激情在线| 一区二区免费在线| 色综合天天综合网天天狠天天 | 日韩视频在线观看一区二区| 国产婷婷色一区二区三区四区 | 亚洲不卡av一区二区三区| 色综合久久久久综合体| xvideos.蜜桃一区二区| 日韩在线播放一区二区| 欧美日韩亚州综合| 欧美成人一区二区| 亚洲男人的天堂网| 专区另类欧美日韩| 久久久国际精品| 欧美日韩极品在线观看一区| 成人污污视频在线观看| 日韩区在线观看| 日韩欧美国产午夜精品| eeuss影院一区二区三区| 韩国午夜理伦三级不卡影院| 精品日韩成人av| 欧洲精品一区二区三区在线观看| 另类小说视频一区二区| 久久女同性恋中文字幕| 成人黄色国产精品网站大全在线免费观看| 国产蜜臀97一区二区三区 | 91高清视频在线| 国产专区欧美精品| 亚洲一级二级三级在线免费观看| 欧美一区二区三区喷汁尤物| 日韩在线一区二区| 国产精品嫩草99a| 国产日韩欧美精品在线| 丁香婷婷综合色啪| 午夜电影一区二区三区| 国产视频亚洲色图| 91精品国产福利| 99久久精品免费| 国产成人8x视频一区二区| 免费xxxx性欧美18vr| 亚洲成人资源网| 亚洲一区在线观看视频| 亚洲一区二区三区三| 香蕉久久夜色精品国产使用方法| 亚洲一区二区三区四区在线观看| 国产精品青草综合久久久久99| 91精品久久久久久久久99蜜臂| 欧美系列一区二区| 这里是久久伊人| 久久精品一区八戒影视| 中文字幕在线不卡| 亚洲欧洲在线观看av| 悠悠色在线精品| 麻豆精品久久久| av激情综合网| 日韩欧美国产一区在线观看| 国产日韩欧美麻豆| 三级不卡在线观看| 国产激情一区二区三区| 欧美亚洲图片小说| 欧美激情一区二区三区蜜桃视频| 亚洲欧洲日韩一区二区三区| 亚洲成人av资源| 99视频在线精品| 精品国产成人系列| 另类调教123区| 日韩亚洲欧美中文三级| 樱桃国产成人精品视频| 国产福利视频一区二区三区| 欧美岛国在线观看| 日日夜夜精品视频免费| 风间由美一区二区三区在线观看| 欧美巨大另类极品videosbest| www国产成人| 麻豆精品一二三| 欧美三级电影网站| 精品福利一区二区三区| 丝袜国产日韩另类美女| 欧美乱熟臀69xxxxxx| 欧美电影精品一区二区| 日欧美一区二区| 日韩免费视频线观看| 国产乱码精品一区二区三区av| 欧美一区二区大片| 国产伦精品一区二区三区免费迷| 2014亚洲片线观看视频免费| 精品一区二区三区久久| 久久精品欧美日韩精品| 91老师国产黑色丝袜在线| 午夜久久久久久| 国产一区二区三区最好精华液| 丁香啪啪综合成人亚洲小说| 亚洲精品视频在线看| 丝袜脚交一区二区| 国产美女在线观看一区| 高清不卡一区二区在线| 午夜欧美电影在线观看| 国产裸体歌舞团一区二区| 成人av在线网站| 丁香啪啪综合成人亚洲小说| 色欧美日韩亚洲| 国产精品久久久久久久午夜片| 秋霞av亚洲一区二区三| 精品一区二区三区的国产在线播放 | 成人18视频在线播放| 亚洲精品日产精品乱码不卡| 欧美mv日韩mv| 欧美一级欧美三级| 色婷婷av一区二区三区大白胸| 日韩一区精品视频| 一区二区三区在线免费视频| 中文字幕一区二区三区色视频| 日韩一区二区三区视频| 91福利区一区二区三区| 日本高清不卡视频| 国产伦精品一区二区三区免费迷| 久久国产福利国产秒拍| 国产一区二区91| 香蕉成人啪国产精品视频综合网| 欧美精品一区二区三区蜜桃| 免费成人你懂的| 裸体在线国模精品偷拍| 蜜桃久久av一区| 日本欧美一区二区三区乱码| 五月激情丁香一区二区三区| 一区二区三区av电影| 日精品一区二区三区| 奇米精品一区二区三区四区| 亚洲成人中文在线| 日韩精品一区第一页| 蜜臀久久99精品久久久久宅男| 国内偷窥港台综合视频在线播放| 日韩成人精品视频| 国产成人精品亚洲日本在线桃色| 国产精品99久久久久久似苏梦涵 | 一区二区理论电影在线观看| 一区av在线播放| 国产一区二区三区美女| 成人av集中营| 国产女主播在线一区二区| 亚洲影院免费观看| 91在线播放网址| 欧美国产日韩一二三区| 久久97超碰色| 91精品在线免费| 亚洲福利一二三区| 91电影在线观看| 日本一区二区三区久久久久久久久不 | 成人ar影院免费观看视频| 日韩精品最新网址| 蜜桃视频第一区免费观看| 欧美电影影音先锋| 日本不卡高清视频| 欧美一级在线免费| 国产中文字幕一区| 国产嫩草影院久久久久| 成人av资源站| 亚洲少妇屁股交4| 欧美无砖专区一中文字| 日日摸夜夜添夜夜添国产精品| 欧美日韩一区中文字幕| 首页欧美精品中文字幕| 日韩一二三区视频| 成人综合在线观看| 亚洲午夜免费电影| 精品国产髙清在线看国产毛片| 成人午夜视频免费看| 亚洲人成人一区二区在线观看| 福利一区在线观看| 亚洲第四色夜色| 日韩欧美黄色影院| 成人黄色免费短视频| 亚洲自拍与偷拍| 欧美日本一区二区在线观看| 久久综合久色欧美综合狠狠| 成人精品一区二区三区中文字幕| 亚洲老妇xxxxxx| 日韩久久一区二区| 国产91高潮流白浆在线麻豆 | 国产日韩高清在线| 欧美婷婷六月丁香综合色| 亚洲激情在线播放| 精品成人在线观看| 欧美日韩国产乱码电影| 高清不卡一二三区| 韩国女主播一区二区三区| 一区二区高清视频在线观看| 久久精品夜色噜噜亚洲aⅴ| 欧美一级在线观看| 日韩欧美aaaaaa| 在线电影一区二区三区| 色综合久久天天综合网|