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