秒殺系統(tǒng)設(shè)計(jì)思路

一清笨、限流與降級(jí)

客戶端限流

  1. 按鈕置灰
  2. js控制每秒只能發(fā)送一個(gè)請(qǐng)求

站點(diǎn)層限流

1. Nginx限流

Nginx官方版本限制IP的連接和并發(fā)分別有兩個(gè)模塊:

  • limit_req_zone: 用來(lái)限制單位時(shí)間內(nèi)的請(qǐng)求數(shù)丹禀,即速率限制,采用的漏桶算法。
  • limit_req_conn: 用來(lái)限制同一時(shí)間連接數(shù),即并發(fā)限制。
2. 站點(diǎn)層限流

客戶端限流一般可以限制住普通用戶,對(duì)于高端用戶阅签,則可能使用腳本刷,或者實(shí)際搶購(gòu)的用戶量確實(shí)大蝎抽,故需要在站點(diǎn)層進(jìn)行限流政钟,如單個(gè)部署實(shí)例的每秒最大請(qǐng)求數(shù),每個(gè)用戶每秒的最大請(qǐng)求或者通過(guò)Redis記錄和限制單個(gè)用戶只能請(qǐng)求一次樟结。

寫(xiě)流量
  • 根據(jù)uuid限制每個(gè)用戶每秒只能一個(gè)請(qǐng)求养交,如使用guava的RateLimiter在進(jìn)程限流,故如果多個(gè)節(jié)點(diǎn)狭吼,則每個(gè)用戶可請(qǐng)求數(shù)量實(shí)際是節(jié)點(diǎn)個(gè)數(shù)倍层坠;或者通過(guò)Nginx將相同的uuid轉(zhuǎn)發(fā)到相同的機(jī)器上面。
讀流量:
  • 頁(yè)面緩存和頁(yè)面數(shù)據(jù)緩存刁笙。頁(yè)面緩存可以是進(jìn)程緩存破花,頁(yè)面數(shù)據(jù)緩存一般是分布式緩存,保持各節(jié)點(diǎn)的數(shù)據(jù)一致性疲吸,如庫(kù)存數(shù)量可以放到分布式緩存中座每。

降級(jí)

  • 如果流量太大,導(dǎo)致站點(diǎn)層限流后還是出現(xiàn)問(wèn)題掛了或者站點(diǎn)層沒(méi)問(wèn)題摘悴,隊(duì)列出問(wèn)題了峭梳,則需要采取降級(jí)策略。
  • 對(duì)于站點(diǎn)層出問(wèn)題蹂喻,則可以在客戶端直接提示“服務(wù)器繁忙葱椭,稍后再試”。
  • 對(duì)于隊(duì)列掛了或者Redis掛了無(wú)法讀取到庫(kù)存信息口四,則可以在站點(diǎn)層降級(jí)處理孵运,直接返回和提示“搶購(gòu)人數(shù)太多,請(qǐng)稍后嘗試”蔓彩。

二治笨、隊(duì)列削峰

通過(guò)第一步限流后,將合法流量放到一個(gè)隊(duì)列中赤嚼,實(shí)現(xiàn)流量削峰旷赖,達(dá)到流量可控和異步處理。

入隊(duì)條件

  • 秒殺的數(shù)量有限更卒,所以不需要將第一步限流中成功通過(guò)的所有請(qǐng)求都放到隊(duì)列中等孵,而是可以先將庫(kù)存數(shù)量放到分布式緩存中,如Redis逞壁,
    然后先檢查庫(kù)存是否還有流济,有則扣減庫(kù)存锐锣,因?yàn)镽edis是單線程的腌闯,故是有序绳瘟,線程安全的,扣減成功姿骏,則將該請(qǐng)求放到隊(duì)列中糖声;
    否則庫(kù)存不足,直接返回?fù)屬?gòu)?fù)戤叿质荩蛘呖梢詢?yōu)化一下說(shuō)“搶購(gòu)?fù)戤呎盒海绻行』锇榉艞墸梢岳^續(xù)搶購(gòu)”來(lái)避免隊(duì)列消息處理失敗導(dǎo)致還有沒(méi)賣(mài)完嘲玫。

請(qǐng)求響應(yīng)

  • 入隊(duì)成功或者失敗都可以將該請(qǐng)求直接返回了悦施,不過(guò)頁(yè)面可以顯示等待中或者提示搶購(gòu)結(jié)果稍后通知,如現(xiàn)在很多搶票都是這樣的去团。

三抡诞、服務(wù)層異步處理

  • 服務(wù)層消費(fèi)隊(duì)列的數(shù)據(jù),由于此時(shí)速度是可控的土陪,故可以起一個(gè)后臺(tái)服務(wù)節(jié)點(diǎn)即可昼汗,消費(fèi)隊(duì)列的數(shù)據(jù),進(jìn)行下單操作鬼雀,遞減數(shù)據(jù)庫(kù)庫(kù)存顷窒。
  • 如果消費(fèi)隊(duì)列的某個(gè)數(shù)據(jù)失敗,可以采用fail-fast的原則源哩,直接提示失敗鞋吉,不需要進(jìn)行重試之類的復(fù)雜操作。

四励烦、搶購(gòu)結(jié)果通知

由于使用了隊(duì)列來(lái)異步處理谓着,即入隊(duì)后或者庫(kù)存不足無(wú)法入隊(duì),該次搶購(gòu)請(qǐng)求是直接返回了的崩侠,故對(duì)于搶購(gòu)結(jié)果是需要進(jìn)行額外通知的漆魔。

1. 客戶端輪詢

可以通過(guò)客戶端定時(shí)請(qǐng)求服務(wù)端,如每秒發(fā)送一個(gè)請(qǐng)求却音,如果成功改抡,則提示搶購(gòu)成功;失敗系瓢,則返回失敗阿纤。例如,客戶端可以在沒(méi)有輪詢到處理結(jié)果時(shí)提示“搶購(gòu)中夷陋,請(qǐng)耐心等待”欠拾,如果輪詢到結(jié)果則提示成功或失敗胰锌。

2. 消息推送

另外一種方式可以是直接通過(guò)消息推送的方式來(lái)通知用戶搶購(gòu)結(jié)果。

完整架構(gòu)示意圖

秒殺.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末藐窄,一起剝皮案震驚了整個(gè)濱河市资昧,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌荆忍,老刑警劉巖格带,帶你破解...
    沈念sama閱讀 218,451評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異刹枉,居然都是意外死亡叽唱,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)微宝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)棺亭,“玉大人,你說(shuō)我怎么就攤上這事蟋软∠庹” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,782評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵钟鸵,是天一觀的道長(zhǎng)钉稍。 經(jīng)常有香客問(wèn)我,道長(zhǎng)棺耍,這世上最難降的妖魔是什么贡未? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,709評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮蒙袍,結(jié)果婚禮上俊卤,老公的妹妹穿的比我還像新娘。我一直安慰自己害幅,他們只是感情好消恍,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,733評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著以现,像睡著了一般狠怨。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上邑遏,一...
    開(kāi)封第一講書(shū)人閱讀 51,578評(píng)論 1 305
  • 那天佣赖,我揣著相機(jī)與錄音,去河邊找鬼记盒。 笑死憎蛤,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播俩檬,決...
    沈念sama閱讀 40,320評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼萎胰,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了棚辽?” 一聲冷哼從身側(cè)響起技竟,我...
    開(kāi)封第一講書(shū)人閱讀 39,241評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎晚胡,沒(méi)想到半個(gè)月后灵奖,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體嚼沿,經(jīng)...
    沈念sama閱讀 45,686評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡估盘,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,878評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了骡尽。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片遣妥。...
    茶點(diǎn)故事閱讀 39,992評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖攀细,靈堂內(nèi)的尸體忽然破棺而出箫踩,到底是詐尸還是另有隱情,我是刑警寧澤谭贪,帶...
    沈念sama閱讀 35,715評(píng)論 5 346
  • 正文 年R本政府宣布境钟,位于F島的核電站,受9級(jí)特大地震影響俭识,放射性物質(zhì)發(fā)生泄漏慨削。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,336評(píng)論 3 330
  • 文/蒙蒙 一套媚、第九天 我趴在偏房一處隱蔽的房頂上張望缚态。 院中可真熱鬧,春花似錦堤瘤、人聲如沸玫芦。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,912評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)桥帆。三九已至,卻和暖如春慎皱,著一層夾襖步出監(jiān)牢的瞬間老虫,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,040評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工宝冕, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留张遭,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,173評(píng)論 3 370
  • 正文 我出身青樓地梨,卻偏偏與公主長(zhǎng)得像菊卷,于是被迫代替她去往敵國(guó)和親缔恳。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,947評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容