|
普遍使用的php緩存技術(shù)
php緩存技術(shù)之?dāng)?shù)據(jù)緩存:
這里所說(shuō)的數(shù)據(jù)緩存是指數(shù)據(jù)庫(kù)查詢緩存,每次訪問(wèn)頁(yè)面的時(shí)候,都會(huì)先檢測(cè)相應(yīng)的緩存數(shù)據(jù)是否存在,如果不存在,就連接數(shù)據(jù)庫(kù),得到數(shù)據(jù),并把查詢結(jié)果序列化后保存到文件中,以后同樣的查詢結(jié)果就直接從緩存文件中獲得。
php緩存技術(shù)之頁(yè)面緩存:
每次訪問(wèn)頁(yè)面的時(shí)候,都會(huì)先檢測(cè)相應(yīng)的緩存頁(yè)面文件是否存在,如果不存在,就連接數(shù)據(jù)庫(kù),得到數(shù)據(jù),顯示頁(yè)面并同時(shí)生成緩存頁(yè)面文件,這樣下次訪問(wèn)的時(shí)候頁(yè)面文件就發(fā)揮作用了。(模板引擎和網(wǎng)上常見(jiàn)的一些緩存類通常有此功能)
php緩存技術(shù)之內(nèi)存緩存:
在里就不介紹了,不是本文所要討論的,只簡(jiǎn)單提一下:
Memcached是高性能的,分布式的內(nèi)存對(duì)象緩存系統(tǒng),用于在動(dòng)態(tài)應(yīng)用中減少數(shù)據(jù)庫(kù)負(fù)載,提升訪問(wèn)速度。
dbcached 是一款基于 Memcached 和 NMDB 的分布式 key-value 數(shù)據(jù)庫(kù)內(nèi)存緩存系統(tǒng)。
以上的緩存技術(shù)雖然能很好的解決頻繁查詢數(shù)據(jù)庫(kù)的問(wèn)題,但其缺點(diǎn)在在于數(shù)據(jù)無(wú)時(shí)效性,下面我給出我在項(xiàng)目中常用的方法:
php緩存技術(shù)之時(shí)間觸發(fā)緩存:
檢查文件是否存在并且時(shí)間戳小于設(shè)置的過(guò)期時(shí)間,如果文件修改的時(shí)間戳比當(dāng)前時(shí)間戳減去過(guò)期時(shí)間戳大,那么就用緩存,否則更新緩存。
設(shè)定時(shí)間內(nèi)不去判斷數(shù)據(jù)是否要更新,過(guò)了設(shè)定時(shí)間再更新緩存。以上只適合對(duì)時(shí)效性要求不高的情況下使用,否則請(qǐng)看下面。
php緩存技術(shù)之內(nèi)容觸發(fā)緩存:
當(dāng)插入數(shù)據(jù)或更新數(shù)據(jù)時(shí),強(qiáng)制更新緩存。
在這里我們可以看到,當(dāng)有大量數(shù)據(jù)頻繁需要更新時(shí),最后都要涉及磁盤讀寫操作。怎么解決呢?我在日常項(xiàng)目中,通常并不緩存所有內(nèi)容,而是緩存一部分不經(jīng)常變的內(nèi)容來(lái)解決。但在大負(fù)荷的情況下,最好要用共享內(nèi)存做緩存系統(tǒng)。
到這里php緩存也許有點(diǎn)解決方案了,但其缺點(diǎn)是,因?yàn)槊看握?qǐng)求仍然要經(jīng)過(guò)php解析,在大負(fù)荷的情況下效率問(wèn)題還是比效嚴(yán)重,在這種情況下,也許會(huì)用到靜態(tài)緩存。
php緩存技術(shù)之靜態(tài)緩存
這里所說(shuō)的靜態(tài)緩存是指HTML緩存,HTML緩存一般是無(wú)需判斷數(shù)據(jù)是否要更新的,因?yàn)橥ǔT谑褂肏TML的場(chǎng)合一般是不經(jīng)常變動(dòng)內(nèi)容的頁(yè)面。數(shù)據(jù)更新的時(shí)候把HTML也強(qiáng)制更新一下就可以了。
php技術(shù):PHP緩存技術(shù)的使用說(shuō)明,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。