- 相關(guān)推薦
Web系統(tǒng)架構(gòu)的性能優(yōu)化
隨著網(wǎng)絡(luò)的發(fā)展,使得許多系統(tǒng)開發(fā)、設(shè)計(jì)者對(duì)系統(tǒng)的設(shè)計(jì)、維護(hù)要求越來越高。那么如何能使系統(tǒng)的性能得到更好的運(yùn)用,我們一起來看看!
1 靜態(tài)頁面
大家都知道,效率最高、消耗最小的就是純靜態(tài)化的html頁面,所以要盡可能使系統(tǒng)上的頁面采用靜態(tài)頁面來實(shí)現(xiàn),這個(gè)最簡(jiǎn)單的方法其實(shí)也是最有效的方法。但是對(duì)于內(nèi)容多且頻繁更新的系統(tǒng),無法全部手動(dòng)去逐個(gè)實(shí)現(xiàn),也許可以采用信息發(fā)布系統(tǒng)CMS來管理和實(shí)現(xiàn)。盡可能的靜態(tài)化也是提高性能的必要手段,同時(shí)頁面靜態(tài)化也是某些緩存策略使用的手段,對(duì)于系統(tǒng)中頻繁使用數(shù)據(jù)庫查詢但內(nèi)容更新很小的應(yīng)用,可以考慮使用頁面靜態(tài)化來實(shí)現(xiàn),這些信息都可以進(jìn)行后臺(tái)管理并且存儲(chǔ)在數(shù)據(jù)庫中,這些信息其實(shí)大量被前臺(tái)程序調(diào)用,我們可以采用Ajax的方式來處理相關(guān)的請(qǐng)求操作,針對(duì)于查詢數(shù)據(jù)來說這樣就可以根據(jù)所需來獲取相應(yīng)的數(shù)據(jù),而不必要刷新整個(gè)頁面。其實(shí)我們是不是可以考慮一下,像開發(fā)游戲那樣把相關(guān)的都放到客戶端來做處理呢,這樣就大大減少了服務(wù)器的負(fù)載,服務(wù)器可以更好地提供服務(wù),而不必要去做太多的處理。面向?qū)ο蠡哪_本編程,更好地解決了難于維護(hù)的問題。
注:不建議使用Ext、Dwr等Ajax框架,這些框架都很繁瑣不利于維護(hù),可以使用相對(duì)比較簡(jiǎn)單的Json、JQuery等。
2 程序代碼
程序是構(gòu)成系統(tǒng)的核心,是系統(tǒng)的靈魂。良好的命名規(guī)則與編程規(guī)范可以減少程序代碼之間的冗余,程序編寫的好與壞、性能的高與低都決定了系統(tǒng)是否可以高效率的運(yùn)行;诂F(xiàn)在都是面向接口化編程,就更好地解決了程序的耦合性。分層架構(gòu)與插件化架構(gòu)已成為Web系統(tǒng)架構(gòu)的趨勢(shì),它可以不依賴其他接口或程序使系統(tǒng)也可以運(yùn)行,大大減少系統(tǒng)代碼的重構(gòu),更有效地降低了維護(hù)成本。
3 影像服務(wù)器分離
大家知道,對(duì)于Web服務(wù)器來說,不管是Apache、IIS還是其他容器,影像是最消耗資源的,于是我們有必要將影像與頁面進(jìn)行分離,獨(dú)立的影像服務(wù)器,甚至很多臺(tái)影像服務(wù)器,這樣的架構(gòu)可以降低提供頁面訪問請(qǐng)求的服務(wù)器系統(tǒng)壓力,并且可以保證系統(tǒng)不會(huì)因?yàn)橛跋駟栴}而崩潰。在應(yīng)用服務(wù)器和影像服務(wù)器上,可以進(jìn)行不同的配置優(yōu)化,比如Apache在配置ContentType的時(shí)候可以盡量少支持LoadModule,以保證更高的系統(tǒng)消耗和執(zhí)行效率。京北方也采用了影像服務(wù)器架構(gòu)上的分離,并且還提供了高效率的影像圖片壓縮技術(shù),這樣更好地節(jié)約了影像服務(wù)器的空間,還可以針對(duì)不同要求提取相關(guān)影像。另外在處理靜態(tài)頁面或者圖片、JS等訪問方面,可以考慮使用lighttpd代替Apache,它提供了更輕量級(jí)和更高效的處理能力。
4 數(shù)據(jù)庫集群和庫表散列
金融行業(yè)系統(tǒng)都有復(fù)雜的應(yīng)用,這些應(yīng)用必須使用數(shù)據(jù)庫,那么在面對(duì)大量數(shù)據(jù)處理的時(shí)候,數(shù)據(jù)庫的瓶頸很快就能顯現(xiàn)出來,這時(shí)一臺(tái)數(shù)據(jù)庫將很快無法滿足應(yīng)用,于是我們需要使用數(shù)據(jù)庫集群或庫表散列。在數(shù)據(jù)庫集群方面,很多數(shù)據(jù)庫都有自己的解決方案,Oracle、Sybase等都有很好的方案。對(duì)于使用了什么樣的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ò)展性。最終可以在配置文件中進(jìn)行簡(jiǎn)單的配置便能讓系統(tǒng)隨時(shí)增加一臺(tái)低成本的數(shù)據(jù)庫進(jìn)來補(bǔ)充系統(tǒng)性能。
5 緩存機(jī)制
緩存一詞搞技術(shù)的都接觸過,很多地方用到緩存。這里先講述最基本的兩種緩存。架構(gòu)方面的緩存,對(duì)Apache比較熟悉的人都能知道Apache提供了自己的modproxy緩存模塊,也可以使用外加的Squid進(jìn)行緩存,這兩種方式均可以有效地提高Apache的訪問響應(yīng)能力。系統(tǒng)程序開發(fā)方面的緩存,Linux上提供的Memcached是常用的緩存方案,可以在Web開發(fā)中使用,可以實(shí)時(shí)或者Cron地把數(shù)據(jù)、對(duì)象等內(nèi)容進(jìn)行緩存。另外在使用Web語言開發(fā)的時(shí)候,各種語言基本都有自己的緩存模塊和方法,Java就更多了。
6 負(fù)載均衡
負(fù)載均衡(Load Balance)建立在現(xiàn)有網(wǎng)絡(luò)結(jié)構(gòu)之上,它提供了一種廉價(jià)、有效、透明的方法擴(kuò)展網(wǎng)絡(luò)設(shè)備和服務(wù)器的帶寬、增加吞吐量、加強(qiáng)網(wǎng)絡(luò)數(shù)據(jù)處理能力、提高網(wǎng)絡(luò)的靈活性和可用性負(fù)載均衡,是系統(tǒng)解決高負(fù)荷訪問和大量并發(fā)請(qǐng)求采用的終極解決辦法。
(1)硬件負(fù)載均衡。硬件負(fù)載均衡解決方案是直接在服務(wù)器和外部網(wǎng)絡(luò)間安裝負(fù)載均衡設(shè)備,這種設(shè)備我們通常稱之為負(fù)載均衡器,由于專門的設(shè)備完成專門的任務(wù),獨(dú)立于操作系統(tǒng),整體性能得到大量提高,加上多樣化的負(fù)載均衡策略、智能化的流量管理,可達(dá)到最佳的負(fù)載均衡需求。硬件負(fù)載均衡在功能、性能上優(yōu)于軟件方式,不過成本昂貴,如果可以的話還是比較好的選擇。
(2)軟件負(fù)載均衡。軟件負(fù)載均衡解決方案是指在一臺(tái)或多臺(tái)服務(wù)器相應(yīng)的操作系統(tǒng)上安裝一個(gè)或多個(gè)附加軟件來實(shí)現(xiàn)負(fù)載均衡,如DNS Load Balance,Connect Control等,它的優(yōu)點(diǎn)是基于特定環(huán)境、配置簡(jiǎn)單、使用靈活、成本低廉,可以滿足一般的負(fù)載均衡需求。
【W(wǎng)eb系統(tǒng)架構(gòu)的性能優(yōu)化】相關(guān)文章:
Linux系統(tǒng)Web服務(wù)器性能測(cè)試09-03
2017最新優(yōu)化Linux系統(tǒng)硬盤性能方法10-14
Web 圖片的優(yōu)化技巧08-21
PHP性能優(yōu)化技巧10-11
PHP性能優(yōu)化小技巧07-11
WEB服務(wù)器的優(yōu)化方法07-08
WEB服務(wù)器的優(yōu)化方法簡(jiǎn)介09-17