PHP緩存技術(shù)的使用說明
更新時間:2011年08月06日 19:41:15 作者:
PHP緩存技術(shù)的應(yīng)用時相當(dāng)普遍的,也許有些人還對這項技術(shù)不太了解,我們現(xiàn)在就為大家詳細(xì)的介紹一下PHP緩存技術(shù)的相關(guān)應(yīng)用技巧。
在大部份情況下我們的網(wǎng)站都會使用數(shù)據(jù)庫作為站點數(shù)據(jù)存儲的容器。當(dāng)你執(zhí)行一個SQL查詢時,典型的處理過程是:連接數(shù)據(jù)庫->準(zhǔn)備 SQL查詢->發(fā)送查詢到數(shù)據(jù)庫->取得數(shù)據(jù)庫返回結(jié)果->關(guān)閉數(shù)據(jù)庫連接。但數(shù)據(jù)庫中有些數(shù)據(jù)是完全靜態(tài)的或不太經(jīng)常變動的,緩存系統(tǒng)會通過把SQL查詢的結(jié)果緩存到一個更快的存儲系統(tǒng)中存儲,從而避免頻繁操作數(shù)據(jù)庫而很大程度上提高了程序執(zhí)行時間,而且緩存查詢結(jié)果也允許你后期處理。
普遍使用的PHP緩存技術(shù)
PHP緩存技術(shù)之?dāng)?shù)據(jù)緩存:
這里所說的數(shù)據(jù)緩存是指數(shù)據(jù)庫查詢緩存,每次訪問頁面的時候,都會先檢測相應(yīng)的緩存數(shù)據(jù)是否存在,如果不存在,就連接數(shù)據(jù)庫,得到數(shù)據(jù),并把查詢結(jié)果序列化后保存到文件中,以后同樣的查詢結(jié)果就直接從緩存文件中獲得。
PHP緩存技術(shù)之頁面緩存:
每次訪問頁面的時候,都會先檢測相應(yīng)的緩存頁面文件是否存在,如果不存在,就連接數(shù)據(jù)庫,得到數(shù)據(jù),顯示頁面并同時生成緩存頁面文件,這樣下次訪問的時候頁面文件就發(fā)揮作用了。(模板引擎和網(wǎng)上常見的一些緩存類通常有此功能)
PHP緩存技術(shù)之內(nèi)存緩存:
在里就不介紹了,不是本文所要討論的,只簡單提一下:
Memcached是高性能的,分布式的內(nèi)存對象緩存系統(tǒng),用于在動態(tài)應(yīng)用中減少數(shù)據(jù)庫負(fù)載,提升訪問速度。
dbcached 是一款基于 Memcached 和 NMDB 的分布式 key-value 數(shù)據(jù)庫內(nèi)存緩存系統(tǒng)。
以上的緩存技術(shù)雖然能很好的解決頻繁查詢數(shù)據(jù)庫的問題,但其缺點在在于數(shù)據(jù)無時效性,下面我給出我在項目中常用的方法:
PHP緩存技術(shù)之時間觸發(fā)緩存:
檢查文件是否存在并且時間戳小于設(shè)置的過期時間,如果文件修改的時間戳比當(dāng)前時間戳減去過期時間戳大,那么就用緩存,否則更新緩存。
設(shè)定時間內(nèi)不去判斷數(shù)據(jù)是否要更新,過了設(shè)定時間再更新緩存。以上只適合對時效性要求不高的情況下使用,否則請看下面。
PHP緩存技術(shù)之內(nèi)容觸發(fā)緩存:
當(dāng)插入數(shù)據(jù)或更新數(shù)據(jù)時,強(qiáng)制更新緩存。
在這里我們可以看到,當(dāng)有大量數(shù)據(jù)頻繁需要更新時,最后都要涉及磁盤讀寫操作。怎么解決呢?我在日常項目中,通常并不緩存所有內(nèi)容,而是緩存一部分不經(jīng)常變的內(nèi)容來解決。但在大負(fù)荷的情況下,最好要用共享內(nèi)存做緩存系統(tǒng)。
到這里PHP緩存也許有點解決方案了,但其缺點是,因為每次請求仍然要經(jīng)過PHP解析,在大負(fù)荷的情況下效率問題還是比效嚴(yán)重,在這種情況下,也許會用到靜態(tài)緩存。
PHP緩存技術(shù)之靜態(tài)緩存
這里所說的靜態(tài)緩存是指HTML緩存,HTML緩存一般是無需判斷數(shù)據(jù)是否要更新的,因為通常在使用HTML的場合一般是不經(jīng)常變動內(nèi)容的頁面。數(shù)據(jù)更新的時候把HTML也強(qiáng)制更新一下就可以了。
普遍使用的PHP緩存技術(shù)
PHP緩存技術(shù)之?dāng)?shù)據(jù)緩存:
這里所說的數(shù)據(jù)緩存是指數(shù)據(jù)庫查詢緩存,每次訪問頁面的時候,都會先檢測相應(yīng)的緩存數(shù)據(jù)是否存在,如果不存在,就連接數(shù)據(jù)庫,得到數(shù)據(jù),并把查詢結(jié)果序列化后保存到文件中,以后同樣的查詢結(jié)果就直接從緩存文件中獲得。
PHP緩存技術(shù)之頁面緩存:
每次訪問頁面的時候,都會先檢測相應(yīng)的緩存頁面文件是否存在,如果不存在,就連接數(shù)據(jù)庫,得到數(shù)據(jù),顯示頁面并同時生成緩存頁面文件,這樣下次訪問的時候頁面文件就發(fā)揮作用了。(模板引擎和網(wǎng)上常見的一些緩存類通常有此功能)
PHP緩存技術(shù)之內(nèi)存緩存:
在里就不介紹了,不是本文所要討論的,只簡單提一下:
Memcached是高性能的,分布式的內(nèi)存對象緩存系統(tǒng),用于在動態(tài)應(yīng)用中減少數(shù)據(jù)庫負(fù)載,提升訪問速度。
dbcached 是一款基于 Memcached 和 NMDB 的分布式 key-value 數(shù)據(jù)庫內(nèi)存緩存系統(tǒng)。
以上的緩存技術(shù)雖然能很好的解決頻繁查詢數(shù)據(jù)庫的問題,但其缺點在在于數(shù)據(jù)無時效性,下面我給出我在項目中常用的方法:
PHP緩存技術(shù)之時間觸發(fā)緩存:
檢查文件是否存在并且時間戳小于設(shè)置的過期時間,如果文件修改的時間戳比當(dāng)前時間戳減去過期時間戳大,那么就用緩存,否則更新緩存。
設(shè)定時間內(nèi)不去判斷數(shù)據(jù)是否要更新,過了設(shè)定時間再更新緩存。以上只適合對時效性要求不高的情況下使用,否則請看下面。
PHP緩存技術(shù)之內(nèi)容觸發(fā)緩存:
當(dāng)插入數(shù)據(jù)或更新數(shù)據(jù)時,強(qiáng)制更新緩存。
在這里我們可以看到,當(dāng)有大量數(shù)據(jù)頻繁需要更新時,最后都要涉及磁盤讀寫操作。怎么解決呢?我在日常項目中,通常并不緩存所有內(nèi)容,而是緩存一部分不經(jīng)常變的內(nèi)容來解決。但在大負(fù)荷的情況下,最好要用共享內(nèi)存做緩存系統(tǒng)。
到這里PHP緩存也許有點解決方案了,但其缺點是,因為每次請求仍然要經(jīng)過PHP解析,在大負(fù)荷的情況下效率問題還是比效嚴(yán)重,在這種情況下,也許會用到靜態(tài)緩存。
PHP緩存技術(shù)之靜態(tài)緩存
這里所說的靜態(tài)緩存是指HTML緩存,HTML緩存一般是無需判斷數(shù)據(jù)是否要更新的,因為通常在使用HTML的場合一般是不經(jīng)常變動內(nèi)容的頁面。數(shù)據(jù)更新的時候把HTML也強(qiáng)制更新一下就可以了。
相關(guān)文章
PHP彈出提示框并跳轉(zhuǎn)到新頁面即重定向到新頁面
本文為大家介紹下使用PHP彈出提示框并跳轉(zhuǎn)到新頁面,也就是大家所認(rèn)為的重定向,下面的示例大家可以參考下2014-01-01