1 數(shù)據(jù)庫的緩存
通常數(shù)據(jù)庫都支持對查詢結(jié)果的緩存,并且有復(fù)雜的機制保證緩存的有效性。對于MySQL,Oracle這樣的數(shù)據(jù)庫,通過合理配置緩存對系統(tǒng)性能帶來的提 升是相當顯著的。
2 數(shù)據(jù)連接驅(qū)動的緩存。
諸如php的ADODB,J2EE的連接驅(qū)動,甚至如果把HIbernate等ORM也看成連接器的話。這里的緩存有效機制就不是那么強了,使用此步的方 法實現(xiàn)緩存的一個最好的優(yōu)點就是我們?nèi)?shù)據(jù)的方式可以保持不變。例如,我調(diào)用
$db->CacheGetAll(“select * from table”); 的語句不需要改變,可以透明實現(xiàn)緩存。這主要應(yīng)用于一些變化不大的數(shù)據(jù)上,例如一些數(shù)據(jù)字典是不經(jīng)常變化的。
3 系統(tǒng)級的緩存
可以在系統(tǒng)內(nèi)通過Cache庫,自行對需要的數(shù)據(jù)進行緩存,例如一個樹樁菜單生成十分消耗資源,那可以將這個生成的樹緩存起來。這樣做的缺點是,當 這顆樹的某些地方被更新時,你需要手動更新緩存內(nèi)的東西。
使用的緩存庫都可以有不同的緩存方法,有的把內(nèi)容放在硬盤上,有的放在內(nèi)存里面,如果你把內(nèi)容模擬成硬盤來緩存,速度當然也能提升不 少。
4 頁面級的緩存
這個在內(nèi)容管理系統(tǒng)里面用的最多。也就是生成靜態(tài)頁面。這里面緩存控制機制最為復(fù)雜,一般也沒有什么包治百病的方法,只有具體情況具體分析。
通常生成的靜態(tài)葉面你需要有一個機制去刪除過時的,或訪問很少的葉面,以保證檢索靜態(tài)葉面的速度。
5 使用預(yù)編譯葉面和加載為FastCGI的辦法
對于PHP,可以使用zend等編譯引擎,對于jsp本身就是預(yù)編譯。而FastCGI的原理就是將腳本預(yù)先加載起來,不用每次執(zhí)行都去讀,這和 JSP預(yù)編成Servlet,然后加載的道理是一樣的。
6 前置緩存
可以使用Squid作為Web服務(wù)器的前置緩存。
7 做集群
對數(shù)據(jù)庫作集群,對web服務(wù)器作集群,對Squild前置機做集群
對于新手來說,如果你的程序要是恰死,首先你要檢查代碼是否有錯誤,是否存在內(nèi)存泄漏,如果都沒有,那么通常問題出在數(shù)據(jù)庫連接上面。
綜合應(yīng)用上面的緩存方法,開發(fā)高負載的Web應(yīng)用成就很容易了。
http://blog.csdn.net/danny_xcz/archive/2006/10/13/1332555.aspx
新聞熱點
疑難解答