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