背景
國(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),提升性能骇径。