亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Redis > 正文

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

2020-03-17 12:39:17
字體:
來源:轉載
供稿:網友

概要:

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

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

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

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

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

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

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

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

1. 設計流程

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

redis+,mysql+quartz,紅包發送,redis+mysql+quartz,紅包發送功能的實現詳解

圖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(未分配),至此,紅包發送的整個流程完成。

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

redis+,mysql+quartz,紅包發送,redis+mysql+quartz,紅包發送功能的實現詳解

圖2 紅包接收流程圖

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

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

redis+,mysql+quartz,紅包發送,redis+mysql+quartz,紅包發送功能的實現詳解

圖3 紅包回收流程圖

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

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

2. 數據模型

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

redis+,mysql+quartz,紅包發送,redis+mysql+quartz,紅包發送功能的實現詳解

圖4 紅包分配數據模型

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

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

3. 并發處理

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

分析:

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

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

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

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

4. 并發測試

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

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

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

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


注:相關教程知識閱讀請移步到Redis頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产视频精品xxxx| 91久久久久久久久久久久久| 成年无码av片在线| 久久99亚洲精品| 国内精品一区二区三区四区| 韩剧1988在线观看免费完整版| 国产日韩精品在线| 国产精品一区专区欧美日韩| 日韩欧美a级成人黄色| 久久在线精品视频| 欧美成人在线免费| 亚洲社区在线观看| 亚洲精品国产成人| 欧美午夜xxx| 国产精品女主播视频| 久久精品国产视频| 日韩欧美亚洲范冰冰与中字| 欧美与欧洲交xxxx免费观看| 色777狠狠综合秋免鲁丝| 亚洲精品资源美女情侣酒店| 亚洲综合视频1区| 美女久久久久久久| 亚洲专区在线视频| 午夜精品一区二区三区在线播放| 宅男66日本亚洲欧美视频| 隔壁老王国产在线精品| 亚洲国产精品推荐| 91嫩草在线视频| 精品亚洲aⅴ在线观看| 国产日韩精品在线观看| 亚洲国产欧美日韩精品| 成人写真视频福利网| 91亚洲国产成人久久精品网站| 国产91精品久久久久| 亚洲a区在线视频| 亚洲二区在线播放视频| 伊人男人综合视频网| 亚洲免费av电影| 欧美裸体xxxx| 精品中文字幕久久久久久| 日本不卡高字幕在线2019| 中文字幕亚洲一区在线观看| 青青a在线精品免费观看| 一本久久综合亚洲鲁鲁| 欧美丰满少妇xxxxx做受| 亚洲欧洲xxxx| 亚洲娇小xxxx欧美娇小| 久久久999精品| 亚洲午夜激情免费视频| 久久亚洲国产精品成人av秋霞| 久久九九全国免费精品观看| 国产日韩在线看片| 一本色道久久综合亚洲精品小说| 日韩va亚洲va欧洲va国产| 97免费在线视频| 青草青草久热精品视频在线网站| 日韩小视频网址| 欧美日本高清一区| 亚洲欧美综合另类中字| 麻豆成人在线看| 38少妇精品导航| 成人av.网址在线网站| 91爱爱小视频k| 久久国产精品久久国产精品| 97国产真实伦对白精彩视频8| 亚洲人成电影在线| 国产精品视频永久免费播放| 亚洲精品电影网在线观看| 51视频国产精品一区二区| 亚洲女性裸体视频| 免费不卡欧美自拍视频| 成人动漫网站在线观看| 亚洲新声在线观看| 亚洲欧美日韩综合| 日韩av综合网站| 久久夜色精品国产欧美乱| 亚洲精品黄网在线观看| 尤物yw午夜国产精品视频明星| 欧美成人午夜激情视频| 中文字幕久久精品| 国产精品一区二区三区在线播放| 2018国产精品视频| 欧美一区二区大胆人体摄影专业网站| 欧美激情伊人电影| 亚洲色图在线观看| 一区二区欧美日韩视频| 亚洲人精品午夜在线观看| 国产精品久久久久久久电影| 欧美理论电影网| 日韩精品在线观看网站| 亚洲午夜精品久久久久久性色| 日韩欧美高清在线视频| 欧美一级成年大片在线观看| 国模私拍一区二区三区| 一本色道久久综合狠狠躁篇怎么玩| 日韩av一区二区在线观看| 久久久久久久久久久免费| 色综合久久88色综合天天看泰| 91在线精品播放| 91在线高清免费观看| 亚洲电影免费观看高清完整版在线观看| 中文字幕精品—区二区| 日韩中文字幕网址| 久久视频免费观看| 国产欧美亚洲视频| 久久久久久12| 久久久久久久久久久亚洲| 色综合老司机第九色激情| 日韩av在线免费播放| 欧美成人精品影院| 日韩精品在线免费播放| 亚洲专区国产精品| 欧美一级电影免费在线观看| 这里只有精品视频在线| 色香阁99久久精品久久久| 欧美资源在线观看| 国产精品高潮在线| 57pao精品| 国产suv精品一区二区| 中文字幕精品国产| 66m—66摸成人免费视频| 久久99久久99精品中文字幕| 韩国精品美女www爽爽爽视频| 日韩在线免费高清视频| 伊人久久精品视频| 欧美精品激情blacked18| 欧美日韩性视频在线| 自拍偷拍亚洲精品| 亚洲视频在线视频| 91精品视频在线免费观看| 日韩有码在线视频| 日韩精品在线播放| 成人h猎奇视频网站| 亚洲欧美中文日韩在线v日本| 亚洲免费一在线| www国产亚洲精品久久网站| 992tv在线成人免费观看| 国产精品久久久久久久电影| 欧美国产日韩在线| 日韩欧美国产成人| 亚洲成色777777女色窝| 日韩精品极品毛片系列视频| 日韩在线观看免费全| 欧美一级bbbbb性bbbb喷潮片| 亚洲精品视频在线观看视频| 一区二区三区天堂av| 中文字幕精品一区久久久久| 亚洲人成亚洲人成在线观看| 亚洲天堂第一页| 国产精品va在线播放我和闺蜜| 中文精品99久久国产香蕉| 国产亚洲欧美视频| 国产精品三级美女白浆呻吟| 在线精品高清中文字幕| 国内精品国产三级国产在线专| 亚洲成色777777女色窝| 久久久久久久久亚洲| 免费97视频在线精品国自产拍| 97av在线视频免费播放| 69久久夜色精品国产7777| 日韩欧美成人区| 欧美在线视频a| 色偷偷噜噜噜亚洲男人的天堂| 亚洲自拍高清视频网站|