個人總結:
前台靜態化:把動態網頁面解析後儲存為靜態頁面
檔案快取:把查詢結果儲存為檔案,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緩衝機制系統,用於在Live App中減少資料庫負載,提升訪問速度。
7、 php的緩衝器:
有eaccelerator, apc, phpa,xcache,這個這個就不說了吧,搜尋一堆一堆的,自己看啦,知道有這玩意就OK
8、 MYSQL緩衝:
這也算非代碼級的,經典的資料庫就是用的這種方式,看下面的已耗用時間,0.09xxx之類的
9、 基於反向 Proxy的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);?>