秒殺開(kāi)發(fā)架構(gòu)

做法一:使用加鎖操作先占有鎖資源,再占有紅包嗡官。

可以使用分布式全局鎖的方式(各種分布式鎖組件或者數(shù)據(jù)庫(kù)鎖)乳怎,先申請(qǐng) lock 該紅包資源且成功后再做后續(xù)操作饶氏。優(yōu)點(diǎn)是不會(huì)出現(xiàn)臟數(shù)據(jù)問(wèn)題芹橡,某一個(gè)時(shí)刻只有一個(gè)應(yīng)用線(xiàn)程持有 lock毒坛,紅包只會(huì)被至多一個(gè)用戶(hù)搶到,數(shù)據(jù)一致性有保障林说。缺點(diǎn)是煎殷,所有請(qǐng)求同一時(shí)刻都在搶紅包 A,下一個(gè)時(shí)刻又都在搶紅包 B腿箩,并且只有一個(gè)搶成功豪直,其他都失敗,效率很低珠移。

做法二:?jiǎn)为?dú)開(kāi)發(fā)請(qǐng)求排隊(duì)調(diào)度模塊弓乙。

排隊(duì)模塊接收用戶(hù)的搶紅包請(qǐng)求,以 FIFO 模式保存下來(lái)剑梳,調(diào)度模塊負(fù)責(zé) FIFO 隊(duì)列的動(dòng)態(tài)調(diào)度唆貌,一旦有空閑資源滑潘,便從隊(duì)列頭部把用戶(hù)的訪(fǎng)問(wèn)請(qǐng)求取出后交給真正提供服務(wù)的模塊處理垢乙。優(yōu)點(diǎn)是,具有中心節(jié)點(diǎn)的統(tǒng)一資源管理语卤,對(duì)系統(tǒng)的可控性強(qiáng)追逮,可深度定制酪刀。缺點(diǎn)是,所有請(qǐng)求流量都會(huì)有中心節(jié)點(diǎn)參與钮孵,效率必然會(huì)比分布式無(wú)中心系統(tǒng)低骂倘,并且,中心節(jié)點(diǎn)也很容易成為整個(gè)系統(tǒng)的性能瓶頸巴席。

做法三:巧用 Redis 特性历涝,使其成為分布式序號(hào)生成器。

前文已經(jīng)提到漾唉,紅包系統(tǒng)所使用的紅包數(shù)據(jù)都是預(yù)先生成好的荧库,我們使用數(shù)字 ID 來(lái)標(biāo)識(shí),這個(gè) ID 是全局唯一的赵刑,所有圍繞紅包的操作都使用這個(gè) ID 作為數(shù)據(jù)的關(guān)聯(lián)項(xiàng)分衫。在實(shí)際的請(qǐng)求流量過(guò)來(lái)時(shí),可采用"分組"處理流量的方式般此。

加MQ排隊(duì)蚪战,分庫(kù)分表。


參考:

https://www.infoq.cn/article/solution-to-the-architecture-of-spike-system

https://www.ibm.com/developerworks/cn/web/wa-design-small-and-good-kill-system/index.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末铐懊,一起剝皮案震驚了整個(gè)濱河市邀桑,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌科乎,老刑警劉巖概漱,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異喜喂,居然都是意外死亡瓤摧,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)玉吁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)照弥,“玉大人,你說(shuō)我怎么就攤上這事进副≌獯В” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵影斑,是天一觀(guān)的道長(zhǎng)给赞。 經(jīng)常有香客問(wèn)我,道長(zhǎng)矫户,這世上最難降的妖魔是什么片迅? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮皆辽,結(jié)果婚禮上柑蛇,老公的妹妹穿的比我還像新娘芥挣。我一直安慰自己,他們只是感情好耻台,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布空免。 她就那樣靜靜地躺著,像睡著了一般盆耽。 火紅的嫁衣襯著肌膚如雪蹋砚。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,708評(píng)論 1 305
  • 那天摄杂,我揣著相機(jī)與錄音都弹,去河邊找鬼。 笑死匙姜,一個(gè)胖子當(dāng)著我的面吹牛畅厢,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播氮昧,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼框杜,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了袖肥?” 一聲冷哼從身側(cè)響起咪辱,我...
    開(kāi)封第一講書(shū)人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎椎组,沒(méi)想到半個(gè)月后油狂,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡寸癌,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年专筷,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蒸苇。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡磷蛹,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出溪烤,到底是詐尸還是另有隱情味咳,我是刑警寧澤,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布檬嘀,位于F島的核電站槽驶,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏鸳兽。R本人自食惡果不足惜掂铐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧堡纬,春花似錦、人聲如沸蒿秦。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)棍鳖。三九已至炮叶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間渡处,已是汗流浹背镜悉。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留医瘫,地道東北人侣肄。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像醇份,于是被迫代替她去往敵國(guó)和親稼锅。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355