第一章 大型網(wǎng)站架構(gòu)演化

1.1大型網(wǎng)站軟件系統(tǒng)的特點(diǎn)

高并發(fā)怎囚,大流量:需要面對(duì)高并發(fā)用戶,大流量訪問

高可用:系統(tǒng)7*24小時(shí)不間斷服務(wù)

海量數(shù)據(jù):需要存儲(chǔ)抵怎、管理海量數(shù)據(jù)莺债,需要使用大量服務(wù)器

用戶分布廣泛紧憾,網(wǎng)絡(luò)情況復(fù)雜

安全環(huán)境惡劣

需求快速變更到千,發(fā)布頻繁

漸進(jìn)式發(fā)展

1.2大型網(wǎng)站架構(gòu)演化發(fā)展歷程

1.2.1初始階段的網(wǎng)站架構(gòu)


應(yīng)用程序、數(shù)據(jù)庫赴穗、文件等資源都在一個(gè)服務(wù)器上憔四。通常服務(wù)器操作系統(tǒng)用Linux,應(yīng)用程序用PHP開發(fā)般眉,部署在apache上了赵,數(shù)據(jù)庫用MySQL

1.2.2應(yīng)用服務(wù)和數(shù)據(jù)服務(wù)分離

應(yīng)用和數(shù)據(jù)分離后整個(gè)網(wǎng)站使用三臺(tái)服務(wù)器:應(yīng)用服務(wù)器、文件服務(wù)器和數(shù)據(jù)庫服務(wù)器


應(yīng)用服務(wù)器處理大量業(yè)務(wù)邏輯甸赃,CPU要求高柿汛;數(shù)據(jù)庫服務(wù)器快速磁盤檢索和數(shù)據(jù)緩存,硬盤內(nèi)存要求高埠对;文件服務(wù)器存儲(chǔ)大量用戶上傳的文件络断,硬盤要求高

存在問題:用戶逐漸增多,數(shù)據(jù)庫壓力太大導(dǎo)致訪問延遲项玛,影響網(wǎng)站性能和用戶體驗(yàn)

1.2.3使用緩存改善網(wǎng)站性能

網(wǎng)絡(luò)訪問特點(diǎn)符合二八定律貌笨,大部分業(yè)務(wù)訪問集中在一小部分?jǐn)?shù)據(jù)上,把這一小部分?jǐn)?shù)據(jù)緩存在內(nèi)存中襟沮,可以減少數(shù)據(jù)庫壓力锥惋。

網(wǎng)站使用的緩存分兩種:緩存在應(yīng)用服務(wù)器上的本地緩存和緩存在專門的分布式緩存服務(wù)器上的遠(yuǎn)程緩存。本地緩存訪問速度快开伏,緩存數(shù)據(jù)量有限膀跌,遠(yuǎn)程分布式緩存可用集群方式,理論上不受內(nèi)存容量限制


存在問題:?jiǎn)我粦?yīng)用服務(wù)器能處理的請(qǐng)求連接有限固灵,在網(wǎng)站訪問高峰期淹父,應(yīng)用服務(wù)器成為整個(gè)網(wǎng)站的瓶頸。

1.2.4使用應(yīng)用服務(wù)器集群改善網(wǎng)站的并發(fā)處理能力

應(yīng)用服務(wù)器實(shí)現(xiàn)集群是網(wǎng)站可伸縮性架構(gòu)設(shè)計(jì)中較為簡(jiǎn)單成熟的一種怎虫,通過負(fù)載均衡調(diào)度服務(wù)器暑认,將用戶瀏覽器訪問請(qǐng)求分發(fā)到應(yīng)用服務(wù)器集群的任何一臺(tái)服務(wù)器上困介。


1.2.5數(shù)據(jù)庫讀寫分離

網(wǎng)站使用緩存后,絕大部分?jǐn)?shù)據(jù)操作訪問都可以不通過數(shù)據(jù)庫就能完成蘸际,但仍有一部分讀操作和全部寫操作需要訪問數(shù)據(jù)庫座哩,當(dāng)用戶達(dá)到一定規(guī)模,數(shù)據(jù)庫因負(fù)載壓力過高而成為網(wǎng)站瓶頸粮彤。

目前主流數(shù)據(jù)庫提供主從熱備功能根穷,通過配置兩臺(tái)數(shù)據(jù)庫主從關(guān)系,可以將一臺(tái)數(shù)據(jù)庫服務(wù)器數(shù)據(jù)更新同步到另一臺(tái)服務(wù)器导坟。網(wǎng)站利用這一功能屿良,實(shí)現(xiàn)數(shù)據(jù)庫讀寫分離,改善負(fù)載壓力惫周。


應(yīng)用服務(wù)器寫數(shù)據(jù)時(shí)尘惧,訪問主數(shù)據(jù)庫,主數(shù)據(jù)庫通過主從復(fù)制機(jī)制將數(shù)據(jù)更新到從數(shù)據(jù)庫递递,這樣應(yīng)用服務(wù)器讀數(shù)據(jù)就可以通過從數(shù)據(jù)庫獲得數(shù)據(jù)喷橙。

1.2.6使用反向代理和CDN加速網(wǎng)站響應(yīng)

CDN和反向代理的基本原理都是緩存,區(qū)別在于CDN部署在網(wǎng)絡(luò)供應(yīng)商機(jī)房登舞,用戶請(qǐng)求網(wǎng)站服務(wù)時(shí)可以從距離最近的機(jī)房獲取數(shù)據(jù)贰逾;反向代理則部署在網(wǎng)站中心機(jī)房,用戶請(qǐng)求到達(dá)中心機(jī)房后菠秒,先訪問反向代理服務(wù)器疙剑,如果反向代理服務(wù)器緩存著用戶請(qǐng)求的資源,就直接返回給用戶践叠。


1.2.7使用分布式文件系統(tǒng)和分布式數(shù)據(jù)庫系統(tǒng)

分布式數(shù)據(jù)庫是網(wǎng)站數(shù)據(jù)庫拆分的最后手段言缤,只有在單表數(shù)據(jù)規(guī)模非常龐大的時(shí)候才使用。網(wǎng)站常用的數(shù)據(jù)庫拆分手段是業(yè)務(wù)分庫酵熙,將不同業(yè)務(wù)的數(shù)據(jù)庫部署在不同的物理服務(wù)器上轧简。


1.2.8使用NoSQL和搜索引擎

網(wǎng)站需要采用一些非關(guān)系數(shù)據(jù)庫技術(shù)如NoSQL和非數(shù)據(jù)庫查詢技術(shù)如搜索引擎


1.2.9業(yè)務(wù)拆分

大型網(wǎng)站為了應(yīng)對(duì)日益復(fù)雜的業(yè)務(wù)場(chǎng)景,將整個(gè)網(wǎng)站業(yè)務(wù)分成不同的產(chǎn)品線匾二,如大型購物網(wǎng)站將首頁哮独、商鋪、訂單察藐、買家皮璧、賣家等拆分成不同的產(chǎn)品線分歸不同的業(yè)務(wù)團(tuán)隊(duì)負(fù)責(zé)。

應(yīng)用之間通過超鏈接建立關(guān)系分飞,也可以通過消息隊(duì)列進(jìn)行數(shù)據(jù)分發(fā)悴务,最多的還是訪問同一個(gè)數(shù)據(jù)存儲(chǔ)系統(tǒng)來構(gòu)成一個(gè)關(guān)聯(lián)的完整系統(tǒng)。


1.2.10分布式服務(wù)

每一個(gè)應(yīng)用都需要執(zhí)行許多相同的業(yè)務(wù)操作時(shí),如用戶管理讯檐、商品管理等羡疗,可以將這些共用的業(yè)務(wù)提取出來,獨(dú)立部署别洪。由這些可復(fù)用的業(yè)務(wù)連接數(shù)據(jù)庫叨恨,提供共用業(yè)務(wù)服務(wù),而應(yīng)用系統(tǒng)只需要管理用戶界面挖垛,通過分布式服務(wù)調(diào)用公用業(yè)務(wù)服務(wù)完成具體業(yè)務(wù)操作即可痒钝。


1.3大型網(wǎng)站架構(gòu)演化的價(jià)值觀

1.3.1大型網(wǎng)站架構(gòu)技術(shù)的核心價(jià)值是隨網(wǎng)站所靈活應(yīng)對(duì)

1.3.2驅(qū)動(dòng)大型網(wǎng)站技術(shù)發(fā)展的主要力量是網(wǎng)站的業(yè)務(wù)發(fā)展

1.4網(wǎng)站架構(gòu)設(shè)計(jì)誤區(qū)

1.4.1一味追隨大公司的解決方案

1.4.2為了技術(shù)而技術(shù)

1.4.3企圖用技術(shù)解決所有問題

技術(shù)是用來解決業(yè)務(wù)問題的,而業(yè)務(wù)的問題也可以通過業(yè)務(wù)的手段去解決

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末痢毒,一起剝皮案震驚了整個(gè)濱河市送矩,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌哪替,老刑警劉巖栋荸,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異夷家,居然都是意外死亡蒸其,警方通過查閱死者的電腦和手機(jī)敏释,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門库快,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人钥顽,你說我怎么就攤上這事义屏。” “怎么了蜂大?”我有些...
    開封第一講書人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵闽铐,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我奶浦,道長(zhǎng)兄墅,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任澳叉,我火速辦了婚禮隙咸,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘成洗。我一直安慰自己五督,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開白布瓶殃。 她就那樣靜靜地躺著充包,像睡著了一般。 火紅的嫁衣襯著肌膚如雪遥椿。 梳的紋絲不亂的頭發(fā)上基矮,一...
    開封第一講書人閱讀 49,007評(píng)論 1 284
  • 那天淆储,我揣著相機(jī)與錄音,去河邊找鬼家浇。 笑死遏考,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蓝谨。 我是一名探鬼主播灌具,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼譬巫!你這毒婦竟也來了咖楣?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤芦昔,失蹤者是張志新(化名)和其女友劉穎诱贿,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體咕缎,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡珠十,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了凭豪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片焙蹭。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖嫂伞,靈堂內(nèi)的尸體忽然破棺而出孔厉,到底是詐尸還是另有隱情,我是刑警寧澤帖努,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布撰豺,位于F島的核電站,受9級(jí)特大地震影響拼余,放射性物質(zhì)發(fā)生泄漏污桦。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一匙监、第九天 我趴在偏房一處隱蔽的房頂上張望凡橱。 院中可真熱鬧,春花似錦舅柜、人聲如沸梭纹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽变抽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間绍载,已是汗流浹背诡宗。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留击儡,地道東北人塔沃。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像阳谍,于是被迫代替她去往敵國和親蛀柴。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345

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