《JAVA——幫你解決高并發(fā)秒殺》

準(zhǔn)備

? ? 首先我們要考慮的是為什么要解決高并發(fā)炼列,高并發(fā)瓶頸出現(xiàn)在哪里圆恤,有了解過的朋友肯定知道是在數(shù)據(jù)庫,因?yàn)樵诖罅空?qǐng)求去操作數(shù)據(jù)庫時(shí)會(huì)出現(xiàn)數(shù)據(jù)的錯(cuò)亂队伟,超賣穴吹,系統(tǒng)崩潰,mysql死鎖等現(xiàn)象嗜侮。

【思路】

(一)港令、 頁面靜態(tài)化:就是將整個(gè)頁面存儲(chǔ)到redis中,下次訪問時(shí)去讀取redis中的頁面值

(二)锈颗、主要對(duì)整個(gè)網(wǎng)站的靜態(tài)資源文件進(jìn)行加速顷霹,如圖片,css击吱,js等

(三)淋淀、數(shù)學(xué)驗(yàn)證碼:用戶在計(jì)算驗(yàn)證碼結(jié)果時(shí)可以減少大量請(qǐng)求同時(shí)進(jìn)入,減少redis, mysql覆醇,服務(wù)器的壓力朵纷。

(四)、庫存標(biāo)識(shí):這是一個(gè)巨大優(yōu)化永脓,通過標(biāo)識(shí)來判斷redis的庫存是否足夠袍辞,如不足就中斷去讀取redis庫存。例:boolean over = map.get(goodsId);當(dāng)我們map通過key讀取到value值為true的時(shí)候常摧,就返回錯(cuò)誤提示給用戶搅吁, if(over) { return Result.error(‘庫存不足’); }.....這樣不管以后有多個(gè)請(qǐng)求進(jìn)入都只運(yùn)行兩行代碼威创,以下的操作無法進(jìn)入。

(五)谎懦、生成動(dòng)態(tài)url:主要是防止惡意用戶通過固定url進(jìn)行提前秒殺商品(安全方面問題這個(gè)不可掉以輕心肚豺,你連安全措施都沒做好以下的那些操作都是白搭的)

(六)、 redis預(yù)減庫存:在用戶秒殺商品前去redis獲取當(dāng)前的庫存數(shù)量界拦,然后在秒殺時(shí)候直接減去redis存儲(chǔ)的庫存(大家放心這里Redis和MySQL數(shù)據(jù)是同步的详炬,只要進(jìn)入MQ隊(duì)列操作完成下單,MySQL數(shù)據(jù)庫會(huì)-1數(shù)量)寞奸,從而避開去MySQL讀取庫存數(shù)據(jù)呛谜。

(七)、MQ消息隊(duì)列:它是一個(gè)中間消息鍵枪萄,通過生產(chǎn)者發(fā)送消息給消費(fèi)者隐岛,進(jìn)行業(yè)務(wù)操作,而生產(chǎn)者無需知道執(zhí)行結(jié)果瓷翻,也就是用戶點(diǎn)擊秒殺之后等待處理結(jié)果聚凹,之后再去輪詢查詢處理結(jié)果(異步操作),這樣就避開了不斷請(qǐng)求去操作數(shù)據(jù)庫齐帚。(這里的輪詢查詢也是直接從redis里面去查詢妒牙,因?yàn)槊霘⒊晒χ髸?huì)將秒殺的結(jié)果放到redis中,輪詢時(shí)候通過key去查詢)

(八)对妄、Nginx:解決高并發(fā)的好方法湘今,也就是我們多增加幾個(gè)tomcat服務(wù)器。當(dāng)用戶訪問的時(shí)候剪菱,請(qǐng)求可以提交到空閑的tomcat服務(wù)器上摩瞎。

(九)、數(shù)據(jù)庫集群孝常、庫表散列

①大型網(wǎng)站都有復(fù)雜的應(yīng)用旗们,這些應(yīng)用必須使用數(shù)據(jù)庫,那么在面對(duì)大量訪問的時(shí)候构灸,數(shù)據(jù)庫的瓶頸很快就能顯現(xiàn)出來上渴,這時(shí)一臺(tái)數(shù)據(jù)庫將很快無法滿足應(yīng)用,于是我們需要使用數(shù)據(jù)庫集群或者庫表散列喜颁。

②在數(shù)據(jù)庫集群方面稠氮,很多數(shù)據(jù)庫都有自己的解決方案,Oracle洛巢、Sybase等都有很好的方案括袒,常用的MySQL提供的Master/Slave也是類似的方案,您使用了什么樣的DB稿茉,就參考相應(yīng)的解決方案來實(shí)施即可。

③上面提到的數(shù)據(jù)庫集群由于在架構(gòu)、成本漓库、擴(kuò)張性方面都會(huì)受到所采用DB類型的限制恃慧,于是我們需要從應(yīng)用程序的角度來考慮改善系統(tǒng)架構(gòu),庫表散列是常用并且最有效的解決方案渺蒿。

④我們?cè)趹?yīng)用程序中安裝業(yè)務(wù)和應(yīng)用或者功能模塊將數(shù)據(jù)庫進(jìn)行分離痢士,不同的模塊對(duì)應(yīng)不同的數(shù)據(jù)庫或者表,再按照一定的策略對(duì)某個(gè)頁面或者功能進(jìn)行更小的數(shù)據(jù)庫散列茂装,比如用戶表怠蹂,按照用戶ID進(jìn)行表散列,這樣就能夠低成本的提升系統(tǒng)的性能并且有很好的擴(kuò)展性少态。

(十)城侧、負(fù)載均衡

負(fù)載均衡將是大型網(wǎng)站解決高負(fù)荷訪問和大量并發(fā)請(qǐng)求采用的高端解決辦法。

(十一)反向代理

客戶端直接訪問的服務(wù)器并不是直接提供服務(wù)的服務(wù)器彼妻,它從別的服務(wù)器獲取資源嫌佑,然后將結(jié)果返回給用戶。

代理服務(wù)器和反向代理服務(wù)器:

代理服務(wù)器是代我們?cè)L獲取資源侨歉,然后將結(jié)果返回屋摇。例如,訪問外網(wǎng)的代理服務(wù)器幽邓。反向代理服務(wù)器是我們正常訪問一臺(tái)服務(wù)器的時(shí)候炮温,服務(wù)器自己調(diào)用了別的服務(wù)器。

反向代理就是說牵舵,用戶的請(qǐng)求請(qǐng)求到負(fù)載均衡的設(shè)備上茅特,負(fù)載均衡設(shè)備再講請(qǐng)求分發(fā)到空閑的應(yīng)用服務(wù)器上處理,處理完成之后再通過負(fù)載均衡設(shè)備返回給用戶棋枕,這樣對(duì)于用戶來說白修,后來的分發(fā)是不可見的。

反向代理的實(shí)現(xiàn)

1)需要有一個(gè)負(fù)載均衡設(shè)備來分發(fā)用戶請(qǐng)求重斑,將用戶請(qǐng)求分發(fā)到空閑的服務(wù)器上

2)服務(wù)器返回自己的服務(wù)到負(fù)載均衡設(shè)備

3)負(fù)載均衡將服務(wù)器的服務(wù)返回用戶

代理服務(wù)器我們主動(dòng)使用兵睛,是為我們服務(wù)的,不需要有自己的域名窥浪;反向代理是服務(wù)器自己使用的祖很,我們并不知道,有自己的域名漾脂。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末假颇,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子骨稿,更是在濱河造成了極大的恐慌笨鸡,老刑警劉巖姜钳,帶你破解...
    沈念sama閱讀 212,383評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異形耗,居然都是意外死亡哥桥,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,522評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門激涤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來拟糕,“玉大人,你說我怎么就攤上這事倦踢∷椭停” “怎么了?”我有些...
    開封第一講書人閱讀 157,852評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵辱挥,是天一觀的道長犁嗅。 經(jīng)常有香客問我,道長般贼,這世上最難降的妖魔是什么愧哟? 我笑而不...
    開封第一講書人閱讀 56,621評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮哼蛆,結(jié)果婚禮上蕊梧,老公的妹妹穿的比我還像新娘。我一直安慰自己腮介,他們只是感情好肥矢,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,741評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著叠洗,像睡著了一般甘改。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上灭抑,一...
    開封第一講書人閱讀 49,929評(píng)論 1 290
  • 那天十艾,我揣著相機(jī)與錄音,去河邊找鬼腾节。 笑死忘嫉,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的案腺。 我是一名探鬼主播庆冕,決...
    沈念sama閱讀 39,076評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼劈榨!你這毒婦竟也來了访递?” 一聲冷哼從身側(cè)響起派诬,我...
    開封第一講書人閱讀 37,803評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤汽煮,失蹤者是張志新(化名)和其女友劉穎工坊,沒想到半個(gè)月后缴淋,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,265評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡跌前,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,582評(píng)論 2 327
  • 正文 我和宋清朗相戀三年棕兼,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了陡舅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抵乓。...
    茶點(diǎn)故事閱讀 38,716評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖靶衍,靈堂內(nèi)的尸體忽然破棺而出灾炭,到底是詐尸還是另有隱情,我是刑警寧澤颅眶,帶...
    沈念sama閱讀 34,395評(píng)論 4 333
  • 正文 年R本政府宣布蜈出,位于F島的核電站,受9級(jí)特大地震影響涛酗,放射性物質(zhì)發(fā)生泄漏铡原。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,039評(píng)論 3 316
  • 文/蒙蒙 一商叹、第九天 我趴在偏房一處隱蔽的房頂上張望燕刻。 院中可真熱鬧,春花似錦剖笙、人聲如沸卵洗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽过蹂。三九已至,卻和暖如春聚至,著一層夾襖步出監(jiān)牢的瞬間酷勺,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,027評(píng)論 1 266
  • 我被黑心中介騙來泰國打工扳躬, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留脆诉,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,488評(píng)論 2 361
  • 正文 我出身青樓坦报,卻偏偏與公主長得像库说,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子片择,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,612評(píng)論 2 350

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