百萬(wàn)訪問(wèn)網(wǎng)站的技術(shù)準(zhǔn)備
  • 更新時(shí)間:2025-01-18 02:00:22
  • 網(wǎng)站建設(shè)
  • 發(fā)布時(shí)間:2年前
  • 325

從現(xiàn)在純網(wǎng)站技術(shù)來(lái)看,因?yàn)殚_(kāi)源模式的發(fā)展,現(xiàn)在搭建一個(gè)小網(wǎng)站非常容易,成本也很低,所以很多人把自己的創(chuàng)業(yè)方向定位在了互聯(lián)網(wǎng)應(yīng)用上。這些人大多不是很懂技術(shù),或者不是很精通,而且網(wǎng)站開(kāi)發(fā)和維護(hù)的知識(shí)很零散,學(xué)習(xí)成本太高,所以這篇文章結(jié)合了這些知識(shí)點(diǎn)。訪問(wèn)量幾千的小網(wǎng)站,一天訪問(wèn)量一兩百萬(wàn)的小網(wǎng)站,中間可能會(huì)出現(xiàn)什么問(wèn)題,一開(kāi)始如何做足夠的工作,盡可能避免這些問(wèn)題。

由于您的努力,您網(wǎng)站的訪問(wèn)量逐漸增加。在增加的過(guò)程中,問(wèn)題也可能開(kāi)始出現(xiàn)。因?yàn)閹捲黾?、硬件擴(kuò)容、人員膨脹帶來(lái)的成本增加是顯而易見(jiàn)的,而且有相當(dāng)一部分成本是由代碼重構(gòu)、架構(gòu)重構(gòu),甚至是底層開(kāi)發(fā)語(yǔ)言的更換造成的。最壞的情況是數(shù)據(jù)丟失,所有的努力都是徒勞的。這種成本支出,大部分在一開(kāi)始是可以避免的,先打好基礎(chǔ),以后可以省心省力。

對(duì)于不同的初始投資成本,技術(shù)路線的選擇是不同的。這里假設(shè)網(wǎng)站只是一個(gè)想法,第一年計(jì)劃在服務(wù)器硬件帶寬上投入5萬(wàn)左右。對(duì)于這筆錢,有很多選擇,比如租用虛擬主機(jī),租用單獨(dú)的服務(wù)器,或者現(xiàn)在流行的私有云,或者托管服務(wù)器。對(duì)于前兩種方案,當(dāng)網(wǎng)站發(fā)展到一定規(guī)模后,需要進(jìn)行遷移,然后重新規(guī)劃,顯然影響會(huì)更大。由于服務(wù)器托管是自行配置和完全可控的,具有一定規(guī)模的網(wǎng)站基本都是這種模式。對(duì)于使用自己托管服務(wù)器的網(wǎng)站,開(kāi)頭要注意以下幾點(diǎn)——

一、開(kāi)發(fā)語(yǔ)言

一般來(lái)說(shuō),技術(shù)人員(程序員)會(huì)根據(jù)自己的技術(shù)背景來(lái)選擇自己最熟悉的語(yǔ)言,但是靠自己寫(xiě)程序是不可能永遠(yuǎn)的,所以在語(yǔ)言的選擇上還是要花點(diǎn)心思的。首先明確一點(diǎn),不管用什么語(yǔ)言,最終的代碼質(zhì)量還是要靠管理,所以我們從前期的開(kāi)發(fā)成本來(lái)分析。目前國(guó)內(nèi)流行的適用于網(wǎng)站的語(yǔ)言大致分為五個(gè)陣營(yíng):java、php、net、python、ruby。因?yàn)閜ython和ruby在國(guó)內(nèi)流行的比較晚,所以招人還是比較困難的。net平臺(tái)的人比較多,但是后期需要解決性能問(wèn)題的時(shí)候,對(duì)人員技能的要求比較高。剩下的java和php雇主可以說(shuō)是最多的了。 Java和php從語(yǔ)言層面無(wú)法比較,但是對(duì)于起步階段,應(yīng)用幾乎都是前端網(wǎng)站支持的,php上手容易,編寫(xiě)速度快,有比較大的優(yōu)勢(shì)。至于后端如行為分析、銀行接口、異步消息處理等,真正需要的時(shí)候,需要根據(jù)不同的業(yè)務(wù)需求選擇不同的語(yǔ)言。

二、代碼版本管理

稍大的網(wǎng)站需要使用代碼版本管理。代碼版本管理最大的好處有兩個(gè),一是方便協(xié)同工作,二是有歷史記錄可以查詢比較。代碼版本管理軟件有很多,比如vss/cvs/svn/hg等,目前國(guó)內(nèi)比較流行,svn的普及度還是很高的。

假設(shè)選擇了svn,則有幾個(gè)注意事項(xiàng)。一是使用什么樹(shù)結(jié)構(gòu)。前期可能只有一個(gè)trunk,后期需要建立分支,比如開(kāi)發(fā)分支,live分支,再后來(lái),可能每個(gè)團(tuán)隊(duì)都有一個(gè)分支。建議一開(kāi)始人少的時(shí)候選擇兩個(gè)分支,development和online。各功能本地測(cè)試無(wú)誤后提交給開(kāi)發(fā)分支。最后統(tǒng)一測(cè)試上線的時(shí)候可以合并到線上分支。如果每個(gè)人都建立自己的分支,合并的時(shí)候會(huì)浪費(fèi)很多精力。對(duì)于一天修改幾次的WEB應(yīng)用來(lái)說(shuō),會(huì)花費(fèi)太多的時(shí)間。

手動(dòng)或自動(dòng)將代碼部署到服務(wù)器。手動(dòng)部署相對(duì)簡(jiǎn)單。一般可以在服務(wù)器上直接svn update,或者找一個(gè)新的目錄svn checkout,然后把web根目錄給ln -s。應(yīng)用程序越復(fù)雜,部署就越復(fù)雜。沒(méi)有統(tǒng)一的標(biāo)準(zhǔn)。只是不要使用ftp上傳。首先,上傳時(shí)文件引用不一致錯(cuò)誤率增加。第二,開(kāi)發(fā)者的版本很容易和線上版本不一致,導(dǎo)致我本來(lái)想改個(gè)錯(cuò)別字變成回滾。如果有多臺(tái)服務(wù)器,還是建議自動(dòng)部署。換碼機(jī)暫時(shí)退出當(dāng)前服務(wù)池,更新完成后重新加入。

三、服務(wù)器硬件

在每個(gè)機(jī)房里,光是一臺(tái)服務(wù)器就支持了無(wú)數(shù)個(gè)網(wǎng)站,但是如果資金稍微充足一點(diǎn),建議至少三個(gè)標(biāo)準(zhǔn)配置,分別用于網(wǎng)頁(yè)處理、數(shù)據(jù)庫(kù)、備份。 web服務(wù)器至少需要8G內(nèi)存,double sata raid1,如果經(jīng)濟(jì)稍微寬松一點(diǎn),或者靜態(tài)文件或者圖片比較多,那就15k sas raid10。數(shù)據(jù)庫(kù)至少要有16G內(nèi)存和15k sas raid 10。備份服務(wù)器最好和數(shù)據(jù)庫(kù)服務(wù)器配置在同一級(jí)別。硬件可以是品牌整機(jī),也可以是兼容機(jī),也可以是半品牌半組裝,看經(jīng)濟(jì)能力。當(dāng)然,這是一個(gè)典型的組合。某些類型應(yīng)用的性能瓶頸最先出現(xiàn)在Web端,需要單獨(dú)分析。

Web服務(wù)器可以運(yùn)行程序并充當(dāng)內(nèi)存緩存,而數(shù)據(jù)庫(kù)服務(wù)器只運(yùn)行主數(shù)據(jù)庫(kù)(如果是MySQL),備份服務(wù)器承擔(dān)的更多。 Web配置、緩存配置、數(shù)據(jù)庫(kù)配置必須和前面兩者保持一致,所以如果WEB和數(shù)據(jù)庫(kù)哪一個(gè)出現(xiàn)問(wèn)題,很容易切換備份服務(wù)器臨時(shí)替代,直到問(wèn)題解決。需要注意的是,硬件隨時(shí)都有可能壞掉,尤其是硬盤,所以最好把WEB服務(wù)器和數(shù)據(jù)庫(kù)服務(wù)器放在一起,備份一定不能省略。備份必須是不同的和異步的,可能會(huì)出現(xiàn)斷電和誤操作。導(dǎo)致機(jī)器上的所有數(shù)據(jù)丟失。有許多開(kāi)源備份解決方案可供選擇。最簡(jiǎn)單的就是rsync,用crontab寫(xiě)的,定時(shí)同步。對(duì)于備份和切換,建議多做測(cè)試,選擇最安全最適合業(yè)務(wù)的,盡量異地備份。

四、機(jī)房

盡量不要選擇三種機(jī)房:聯(lián)通訪問(wèn)特別慢的聯(lián)通機(jī)房、電信訪問(wèn)特別慢的聯(lián)通機(jī)房、電信機(jī)房

聯(lián)通訪問(wèn)特別慢的移動(dòng)或鐵通機(jī)房。機(jī)房要盡可能多的實(shí)地參觀,多測(cè)試,找個(gè)網(wǎng)絡(luò)質(zhì)量好,管理嚴(yán)格的機(jī)房。機(jī)房可以說(shuō)是非常重要,直接關(guān)系到網(wǎng)站訪問(wèn)速度,網(wǎng)站訪問(wèn)速度直接關(guān)系到用戶體驗(yàn),訪問(wèn)速度很慢的網(wǎng)站,很難獲得用戶青睞。

五、架構(gòu)

在大方向上,被熟知的架構(gòu)是web負(fù)載均衡+數(shù)據(jù)庫(kù)主從+緩存+分布式存儲(chǔ)+隊(duì)列。在一開(kāi)始,按照可擴(kuò)展的原則設(shè)計(jì)和編程就可以。只是要多考慮緩存失效時(shí)的雪崩效應(yīng)、主從同步的數(shù)據(jù)一致性和時(shí)間差、隊(duì)列的穩(wěn)定性和失敗后的重試策略、文件存儲(chǔ)的效率和備份方式等等意外情況。緩存失效、數(shù)據(jù)庫(kù)復(fù)制中斷、隊(duì)列寫(xiě)入錯(cuò)誤、電源損壞,在實(shí)際運(yùn)維中經(jīng)常發(fā)生,如果不注意這些,出現(xiàn)問(wèn)題時(shí)恢復(fù)期可能會(huì)超出預(yù)期很長(zhǎng)時(shí)間。

六、服務(wù)器軟件

操作系統(tǒng)Linux很流行。在沒(méi)有專業(yè)運(yùn)維人員的情況下,應(yīng)傾向于擇使用的人多、社區(qū)活躍、配置方便、升級(jí)方便的發(fā)行版,例如RH系列、debian、ubuntu server等,硬件和操作系統(tǒng)要一起選擇,看是否有適合的驅(qū)動(dòng),如果確定用某種商業(yè)軟件或解決方案,也要提前知曉其對(duì)哪種操作系統(tǒng)支持最佳。web服務(wù)器方面,apache、nginx、lighttpd三大系列中,apache占有量還是最大,但是想把性能調(diào)教好還是需要很專業(yè)的,nginx和lighttpd在不需要太多調(diào)整的情況下可以達(dá)到一個(gè)比較不錯(cuò)的性能。無(wú)論選擇什么軟件,除非改過(guò)這些軟件或你的程序真的不兼容新版本,否則盡量版本越新越好,版本新,意味著新特性增多、BUG減少、性能增加。一個(gè)典型的php網(wǎng)站,基本上大多數(shù)人都沒(méi)改過(guò)任何服務(wù)器軟件源代碼,絕大多數(shù)情況是能平穩(wěn)的升級(jí)到新版本的。類似于jdk5到 jdk6,python2到python3這類變動(dòng)比較大的升級(jí)還是比較少見(jiàn)的??纯碈hangeLog,看看升級(jí)說(shuō)明,結(jié)合自己情況評(píng)估測(cè)試一下,越早升級(jí)越好,升級(jí)的越晚,所花費(fèi)的成本越高。對(duì)于軟件包,盡量使用發(fā)行版內(nèi)置的包管理工具,沒(méi)有特殊要求時(shí)不建議自己編譯,那樣對(duì)將來(lái)運(yùn)維不利。

七、數(shù)據(jù)庫(kù)

幾乎所有操作最后都要落到數(shù)據(jù)庫(kù)身上,它又最難擴(kuò)展(存儲(chǔ)也挺難)。數(shù)據(jù)庫(kù)常見(jiàn)的擴(kuò)展方法有復(fù)制、分片,設(shè)計(jì)時(shí)要考慮到每種應(yīng)用的數(shù)據(jù)如何復(fù)制、分片,當(dāng)然這種考慮一般會(huì)推遲到技術(shù)設(shè)計(jì)時(shí)期。在初期進(jìn)行數(shù)據(jù)庫(kù)結(jié)構(gòu)設(shè)計(jì)時(shí),要根據(jù)不同的業(yè)務(wù)類型和增長(zhǎng)量預(yù)期來(lái)考慮是否要分庫(kù)、分區(qū),并且盡量不要使用聯(lián)合查詢、不使用自增ID以方便分片。復(fù)制延時(shí)問(wèn)題、主從數(shù)據(jù)庫(kù)數(shù)據(jù)一致性問(wèn)題,可以自己寫(xiě)或者用已有的運(yùn)維工具進(jìn)行檢測(cè)。

用存儲(chǔ)過(guò)程是比較難擴(kuò)展的,這種情形多發(fā)生于傳統(tǒng)C/S,特別是OA系統(tǒng)轉(zhuǎn)換過(guò)來(lái)的開(kāi)發(fā)人員。低成本網(wǎng)站不是一兩臺(tái)小型機(jī)跑一個(gè)數(shù)據(jù)庫(kù)處理所有業(yè)務(wù)的模式,是機(jī)海作戰(zhàn)。方便水平擴(kuò)展比那點(diǎn)預(yù)分析時(shí)間和網(wǎng)絡(luò)傳輸流量要重要的多的多。

另外,現(xiàn)在流行一種概念叫NoSQL,可以理解為非傳統(tǒng)關(guān)系型數(shù)據(jù)庫(kù)。實(shí)際應(yīng)用中,網(wǎng)站有著越來(lái)越多的密集寫(xiě)操作、上億的簡(jiǎn)單關(guān)系數(shù)據(jù)讀取、熱備等,這都不是傳統(tǒng)關(guān)系數(shù)據(jù)庫(kù)所擅長(zhǎng)的,于是就產(chǎn)生了很多非關(guān)系型數(shù)據(jù)庫(kù),比如Redis/TC&TT/MongoDB/Memcachedb等,在測(cè)試中,這些幾乎都達(dá)到了每秒至少一萬(wàn)次的寫(xiě)操作,內(nèi)存型的甚至5萬(wàn)以上。在設(shè)計(jì)時(shí),可根據(jù)業(yè)務(wù)特點(diǎn)和性能要求來(lái)選擇是否使用這類數(shù)據(jù)庫(kù)。例如MongoDB,幾句配置就可以組建一個(gè)復(fù)制+自動(dòng)分片+failover的環(huán)境,文檔化的存儲(chǔ)也簡(jiǎn)化了傳統(tǒng)設(shè)計(jì)庫(kù)結(jié)構(gòu)再開(kāi)發(fā)的模式。但是當(dāng)你決定采用一項(xiàng)技術(shù)時(shí),一定要真正了解其優(yōu)劣,例如可能你所選擇的技術(shù)并不能支持你所需要的事務(wù)和數(shù)據(jù)一致性要求。

八、文件存儲(chǔ)

存儲(chǔ)的分布幾乎跟數(shù)據(jù)庫(kù)擴(kuò)展一樣困難,不過(guò)只有百萬(wàn)的PV的情況下,磁盤IO方面一般不會(huì)成大問(wèn)題,一兩臺(tái)采用SATA做條帶RAID的機(jī)器可以應(yīng)付,反而是自己做異步備份比較復(fù)雜,因?yàn)樾∥募?。如果只有一臺(tái)機(jī)器做存儲(chǔ),可以做簡(jiǎn)單的優(yōu)化,例如放最小縮略圖的分區(qū)和放中等縮略圖的分區(qū),根據(jù)平均大小調(diào)整一下塊大小。存儲(chǔ)要規(guī)劃好目錄結(jié)構(gòu),否則文件增多后維護(hù)起來(lái)復(fù)雜,也不利于擴(kuò)展。同時(shí)還要考慮將來(lái)擴(kuò)容,例如采用LVM,或者把文件根據(jù)不同規(guī)則散列到不同機(jī)器。磁盤IO繁重的情況下更容易出現(xiàn)故障,所以要做好備份,若發(fā)現(xiàn)有盤壞掉,要馬上行動(dòng)更換,很多人的硬盤都是壞了一塊之后,接二連三的壞下去。

為了將來(lái)圖片走cdn做準(zhǔn)備,一開(kāi)始最好就將圖片的域名分開(kāi),且不用主域名。因?yàn)楹芏嗑W(wǎng)站都將cookie設(shè)置到了.domain.ltd,如果圖片也在這個(gè)域名下,很可能因?yàn)閏ookie而造成緩存失效,并且占多余流量,還可能因?yàn)闉g覽器并發(fā)線程限制造成訪問(wèn)緩慢。

九、程序

一定硬件條件下,應(yīng)用能承載多少訪問(wèn)量,很大一部分也取決于程序如何寫(xiě)。程序?qū)懙牟缓茫赡芤蝗f(wàn)的訪問(wèn)都承載不了,寫(xiě)的好,可能一兩臺(tái)機(jī)器就能承擔(dān)幾百萬(wàn)PV。越是復(fù)雜、數(shù)據(jù)實(shí)時(shí)性要求越高的應(yīng)用,優(yōu)化起來(lái)越難,但對(duì)普通網(wǎng)站有一個(gè)統(tǒng)一的思路,就是盡量向前端優(yōu)化、減少數(shù)據(jù)庫(kù)操作、減少磁盤IO。向前端優(yōu)化指的是,在不影響功能和體驗(yàn)的情況下,能在瀏覽器執(zhí)行的不要在服務(wù)端執(zhí)行,能在緩存服務(wù)器上直接返回的不要到應(yīng)用服務(wù)器,程序能直接取得的結(jié)果不要到外部取得,本機(jī)內(nèi)能取得的數(shù)據(jù)不要到遠(yuǎn)程取,內(nèi)存能取到的不要到磁盤取,緩存中有的不要去數(shù)據(jù)庫(kù)查詢。減少數(shù)據(jù)庫(kù)操作指減少更新次數(shù)、緩存結(jié)果減少查詢次數(shù)、將數(shù)據(jù)庫(kù)執(zhí)行的操作盡可能的讓你的程序完成(例如join查詢),減少磁盤IO指盡量不使用文件系統(tǒng)作為緩存、減少讀寫(xiě)文件次數(shù)等。程序優(yōu)化永遠(yuǎn)要優(yōu)化慢的部分,換語(yǔ)法是無(wú)法“優(yōu)化”的。

然而編程時(shí)不應(yīng)該把重點(diǎn)放在優(yōu)化上,應(yīng)該關(guān)注擴(kuò)展性。當(dāng)今的WEB應(yīng)用,需求變化非常之快,適應(yīng)多種需求的架構(gòu)是不存在的,我們的擴(kuò)展性就要把要點(diǎn)放在跟底層交互的架構(gòu)上,例如持久化數(shù)據(jù)的存取規(guī)則、緩存的存取規(guī)則等,還有一些共用服務(wù),例如用戶信息等。先把不變的部分做完善,剩下的部分就很容易將精力放在業(yè)務(wù)邏輯上面了。

關(guān)于作者

劉志一,從1999年做個(gè)人網(wǎng)站開(kāi)始一直專注于互聯(lián)網(wǎng),目前就職于一家垂直行業(yè)C2C網(wǎng)站,做產(chǎn)品和開(kāi)發(fā)方面工作。

我們專注高端建站,小程序開(kāi)發(fā)、軟件系統(tǒng)定制開(kāi)發(fā)、BUG修復(fù)、物聯(lián)網(wǎng)開(kāi)發(fā)、各類API接口對(duì)接開(kāi)發(fā)等。十余年開(kāi)發(fā)經(jīng)驗(yàn),每一個(gè)項(xiàng)目承諾做到滿意為止,多一次對(duì)比,一定讓您多一份收獲!

本文章出于推來(lái)客官網(wǎng),轉(zhuǎn)載請(qǐng)表明原文地址:https://www.tlkjt.com/web/13481.html
推薦文章

在線客服

掃碼聯(lián)系客服

3985758

回到頂部