PHP網頁快取技術優點及程式碼例項
前臺靜態化:把動態頁面解析後儲存為靜態頁面
檔案快取:把查詢結果儲存為檔案,XML
記憶體快取:memcache
php快取器:XCache、eaccelerator等
Memcache是一個高效能的分散式的記憶體物件快取系統,通過在記憶體裡維護一個統一的巨大的hash表,它能夠用來儲存各種格式的資料,包括影象、視訊、檔案以及資料庫檢索的結果等。簡單的說就是將資料呼叫到記憶體中,然後從記憶體中讀取,從而大大提高讀取速度。 Memcache是danga的一個專案,最早是LiveJournal 服務的,最初為了加速 LiveJournal 訪問速度而開發的,後來被很多大型的網站採用。 Memcached是以守護程式方式運行於一個或多個伺服器中,隨時會接收客戶端的連線和操作。
XCache 是一個開源的 opcode 快取器/優化器,這意味著他能夠提高您伺服器上的 PHP 效能. 他通過把編譯 PHP 後的資料緩衝到共享記憶體從而避免重複的編譯過程,能夠直接使用緩衝區已編譯的程式碼從而提高速度. 通常能夠提高您的頁面生成速率 2 到5 倍,降低伺服器負載.
******************************************************************************************************************************************************
1、普遍快取技術:
資料快取:這裡所說的資料快取是指資料庫查詢PHP快取機制,每次訪問頁面的時候,都會先檢測相應的快取資料是否存在,如果不存在,就連線資料庫,得到資料,並把查詢結果序列化後儲存到檔案中,以後同樣的查詢結果就直接從快取表或檔案中獲得。
用的最廣的例子看Discuz的搜尋功能,把結果ID快取到一個表中,下次搜尋相同關鍵字時先搜尋快取表。
舉個常用的方法,多表關聯的時候,把附表中的內容生成陣列儲存到主表的一個欄位中,需要的時候陣列分解一下,這樣的好處是隻讀一個表,壞處就是兩個資料同步會多不少步驟,資料庫永遠是瓶頸,用硬碟換速度,是這個的關鍵點。
2、 頁面快取:
每次訪問頁面的時候,都會先檢測相應的快取頁面檔案是否存在,如果不存在,就連線資料庫,得到資料,顯示頁面並同時生成快取頁面檔案,這樣下次訪問的時候頁面檔案就發揮作用了。(模板引擎和網上常見的一些PHP快取機制類通常有此功能)
3、 時間觸發快取:
檢查檔案是否存在並且時間戳小於設定的過期時間,如果檔案修改的時間戳比當前時間戳減去過期時間戳大,那麼就用快取,否則更新快取。
4、 內容觸發快取:
當插入資料或更新資料時,強制更新PHP快取機制。
5、 靜態快取:
這裡所說的靜態快取是指靜態化,直接生成HTML或XML等文字檔案,有更新的時候重生成一次,適合於不太變化的頁面,這就不說了。
以上內容是程式碼級的解決方案,我直接CP別的框架,也懶得改,內容都差不多,很容易就做到,而且會幾種方式一起用,但下面的內容是伺服器端的快取方案,非程式碼級的,要有多方的合作才能做到
6、 記憶體快取:
Memcached是高效能的,分散式的記憶體物件PHP快取機制系統,用於在動態應用中減少資料庫負載,提升訪問速度。
7、 php的緩衝器:
有eaccelerator, apc, phpa,xcache,這個這個就不說了吧,搜尋一堆一堆的,自己看啦,知道有這玩意就OK
8、 MYSQL快取:
這也算非程式碼級的,經典的資料庫就是用的這種方式,看下面的執行時間,0.09xxx之類的
9、 基於反向代理的Web快取:
如Nginx,SQUID,mod_proxy(apache2以上又分為mod_proxy和mod_cache)
10、 DNS輪詢:
BIND是一款開放原始碼的DNS伺服器軟體,這個要說起來就大了,自己搜尋去,大家知道有這個東西就行了。
我知道的有chinacache等大站就是這樣做的,說簡單點就是多伺服器啦,把同一個頁面或檔案快取到不同的伺服器上,按南北自動解析到相關的伺服器中。
PHP網頁快取例項
- ob_start():頁面快取開始的標誌,此函式一下的內容直至ob_end_flush()或者ob_end_clean()都儲存在頁面快取中;
- ob_get_contents():用來獲取頁面快取中的內容,獲取到以後呢,我們就可以想怎麼處理這些內容都行了,過濾欄位啦,匹配內容啦,都可以~~~ :)
- ob_end_flush():表示頁面快取結束。並且經我驗證,快取的內容將輸出到當前頁面上,也就是可以顯示快取內容。
用此三個php函式,就可以實現強大的功能。如果資料庫查詢量較大,可以用cache來解決這個問題。
首先,設定過期時間,如果要求快取檔案2個小時過期,就可以設定cache_time為3600*2;通過filectime()來獲取快取檔案的建立時間(或 filemtime()獲取修改時間),如果當前時間跟檔案的建立時間超過限定的過期時間,就可以通過上面三個函式,首先從資料庫中取出資料,然後開始快取ob_start(),然後把要生成的頁面的html程式碼寫在快取中,快取結束後通過ob_get_contents()獲取到快取的內容,然後通過fwrite把快取內容寫到靜態頁面html。
如果未過期,直接讀取cache中的靜態頁面即可,避免了大量的資料庫訪問。
<?php $_time =10; $dir="D:\\php\\"; function cache_start($_time,$dir) { $cachefile = $dir.'/'.sha1($_SERVER['REQUEST_URI']).'.html'; $cachetime = $_time; ob_start(); if(file_exists($cachefile) && (time()-filemtime($cachefile) < $cachetime)) { include($cachefile); ob_end_flush(); exit; } } function cache_end($dir) { $cachefile = $dir.'/'.sha1($_SERVER['REQUEST_URI']).'.html'; $fp = fopen($cachefile,'w'); fwrite($fp,ob_get_contents()); fclose($fp); ob_end_flush(); } cache_start($_time,$dir); //以下是輸出的內容,放在cache_start和cache_end兩個方法之間 for ($i=0;$i<5;$i++) { echo $i; sleep(1); } cache_end($dir); ?>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。