簡(jiǎn)易秒殺搶票活動(dòng)實(shí)現(xiàn)

背景

國(guó)慶前幾天,我們產(chǎn)品說俏蛮,營(yíng)銷那邊有個(gè)秒殺演唱會(huì)門票活動(dòng)撑蚌,大概峰值QPS在15k左右,然后放到我們這邊來做搏屑。我們這邊的活動(dòng),日常qps大概在20-30之間粉楚,且設(shè)計(jì)之初辣恋,就沒有考慮過秒殺搶票活動(dòng)。所以模软,得做不少改動(dòng)伟骨。
我們這邊整個(gè)流程分為售賣頁(yè)、填寫頁(yè)燃异、下單三個(gè)接口携狭。其中流量是一個(gè)漏斗型,流量大小依次是:售賣頁(yè) - > 填寫頁(yè) - > 下單

1回俐、調(diào)研

1.1逛腿、預(yù)估相關(guān)頁(yè)面/接口大致的流量

首先,我們需要預(yù)估一個(gè)最開始的入口的流量仅颇。比如我們一開始預(yù)估的售賣頁(yè)的QPS在15k左右单默。然后我們可以統(tǒng)計(jì)下正常情況下的轉(zhuǎn)化率。比如忘瓦,正常的活動(dòng)搁廓,我們的售賣頁(yè)的一天的流量為x
填寫頁(yè)一天的流量為y
下單的一天的流量為z
那么,填寫頁(yè)的流量預(yù)計(jì)為x/y * 15k
下單的流量為x/z*15k

這里僅作為一個(gè)參考

1.1耕皮、統(tǒng)計(jì)相關(guān)被調(diào)用方

首先境蜕,需要整理各個(gè)頁(yè)面調(diào)用了什么接口,然后各個(gè)接口有沒有相關(guān)的依賴(這個(gè)依賴可以是其它接口凌停,也可以是db)粱年,然后各個(gè)依賴的情況。比如我們的售賣頁(yè)只有個(gè)產(chǎn)品售賣信息接口苦锨,但是涉及的調(diào)用的接口有四個(gè)逼泣。當(dāng)我們這邊有很大流量時(shí)趴泌,需要考慮相關(guān)的被調(diào)用方是否也能夠承擔(dān)該流量下的壓力。
我們需要整理一個(gè)文檔或者Excel拉庶,將相關(guān)的接口嗜憔、依賴等羅列出來,并詳細(xì)的填寫被依賴方能支持的qps氏仗。

2吉捶、方案

2.1、簡(jiǎn)化流程

在明確我們這邊的被調(diào)用方之后皆尔,我們需要進(jìn)行評(píng)估:

  • 1呐舔、該依賴是否是必須的,能否通過其它方式減少依賴慷蠕;
    這一步我們可以通過調(diào)整校驗(yàn)步驟等進(jìn)行調(diào)整珊拼,如,庫(kù)存校驗(yàn)放在第一步流炕,如無庫(kù)存澎现,是否可以直接展示已售罄的默認(rèn)頁(yè)面。
  • 2每辟、該依賴一旦崩潰剑辫,會(huì)造成什么影響,是否有兜底的方案渠欺;
    我們需要做好被依賴方崩潰的準(zhǔn)備妹蔽,如產(chǎn)品信息接口/db連接超時(shí)或者返回異常,我們是否有相應(yīng)的異常處理挠将。
  • 3胳岂、是否可以將部分靜態(tài)數(shù)據(jù)或者庫(kù)存限制等,加入緩存捐名;
    比如我們可以將產(chǎn)品信息旦万,提前寫入緩存。一般來說镶蹋,產(chǎn)品的一些基礎(chǔ)數(shù)據(jù)是不會(huì)變化的成艘,或者說很少發(fā)生變化(至少在秒殺的這段時(shí)間內(nèi),基本不會(huì)變化)贺归,這種數(shù)據(jù)淆两,我們甚至可以寫入本地緩存,而非redis(比較讀取redis本身也是會(huì)有網(wǎng)絡(luò)開銷的拂酣,且redis本身也需要支持對(duì)應(yīng)的qps)秋冰。

在我們售賣頁(yè),需要調(diào)用的4個(gè)接口中婶熬,其中一個(gè)是校驗(yàn)可售接口剑勾,正常是去異步調(diào)用的埃撵,在這個(gè)時(shí)候,我們可以將其提前虽另,并且將無庫(kù)存結(jié)果緩存到redis中暂刘。這樣,大部分用戶的請(qǐng)求并不會(huì)打到其它三個(gè)依賴中捂刺,從而減小相關(guān)依賴的壓力谣拣。

2.2、限流

從一開始族展,我們就說我們的流量模型是漏斗型森缠,且流程往下,我們的接口能接受的壓力也越幸歉住(如下單接口贵涵,由于接口中帶有多個(gè)校驗(yàn)邏輯,因此該接口本身所能承載的壓力上限就不會(huì)高)腹殿,因此独悴,我們?cè)谑圪u頁(yè)優(yōu)先限流,在同一時(shí)間锣尉,僅允許x個(gè)人(該變量是可配置的)進(jìn)入售賣頁(yè)。在控制同一時(shí)間僅允許x個(gè)人進(jìn)入頁(yè)面時(shí)决采,有以下幾個(gè)問題需要考慮:
1自沧、當(dāng)用戶離開售賣頁(yè)時(shí),如何識(shí)別树瞭;
2拇厢、用戶應(yīng)該可重入,即刷新不應(yīng)該被限流晒喷;

第一個(gè)問題孝偎,我們是當(dāng)用戶進(jìn)入填寫頁(yè)時(shí),將其移除售賣頁(yè)白名單列表凉敲,同時(shí)衣盾,在將其加入白名單時(shí),本身是有一個(gè)超時(shí)時(shí)間的爷抓,防止用戶一直停留在售賣頁(yè)卻占用資源势决;第二個(gè)問題,我們把用戶的cid作為key蓝撇,這樣用戶刷新時(shí)果复,cid是不變的,也就實(shí)現(xiàn)可重入渤昌。

壓測(cè)

總結(jié)

在做秒殺活動(dòng)時(shí)虽抄,我們需要充分考慮到全流程是否能支持秒殺活動(dòng)走搁,我們的依賴方是否支持我們的這個(gè)流量級(jí)別。由于秒殺對(duì)性能有所要求迈窟,因此私植,我們針對(duì)活動(dòng)中每一個(gè)被依賴方,都進(jìn)行仔細(xì)考慮:我們能否去除這個(gè)依賴菠隆?對(duì)于一些靜態(tài)數(shù)據(jù)的依賴兵琳,我們可以暫時(shí)將其寫入緩存(可以是本地緩存)以減少依賴項(xiàng),提升性能骇径。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末躯肌,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子破衔,更是在濱河造成了極大的恐慌清女,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,607評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件晰筛,死亡現(xiàn)場(chǎng)離奇詭異嫡丙,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)读第,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門曙博,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人怜瞒,你說我怎么就攤上這事父泳。” “怎么了吴汪?”我有些...
    開封第一講書人閱讀 164,960評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵惠窄,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我漾橙,道長(zhǎng)杆融,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,750評(píng)論 1 294
  • 正文 為了忘掉前任霜运,我火速辦了婚禮脾歇,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘觉渴。我一直安慰自己介劫,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評(píng)論 6 392
  • 文/花漫 我一把揭開白布案淋。 她就那樣靜靜地躺著座韵,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上誉碴,一...
    開封第一講書人閱讀 51,604評(píng)論 1 305
  • 那天宦棺,我揣著相機(jī)與錄音,去河邊找鬼黔帕。 笑死代咸,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的成黄。 我是一名探鬼主播呐芥,決...
    沈念sama閱讀 40,347評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼奋岁!你這毒婦竟也來了思瘟?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,253評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤闻伶,失蹤者是張志新(化名)和其女友劉穎滨攻,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蓝翰,經(jīng)...
    沈念sama閱讀 45,702評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡光绕,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了畜份。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片诞帐。...
    茶點(diǎn)故事閱讀 40,015評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖爆雹,靈堂內(nèi)的尸體忽然破棺而出景埃,到底是詐尸還是另有隱情,我是刑警寧澤顶别,帶...
    沈念sama閱讀 35,734評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站拒啰,受9級(jí)特大地震影響驯绎,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜谋旦,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評(píng)論 3 330
  • 文/蒙蒙 一剩失、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧册着,春花似錦拴孤、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春芒粹,著一層夾襖步出監(jiān)牢的瞬間兄纺,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工化漆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留估脆,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,216評(píng)論 3 371
  • 正文 我出身青樓座云,卻偏偏與公主長(zhǎng)得像疙赠,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子朦拖,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評(píng)論 2 355

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