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);
?> 


發佈了143 篇原創文章 · 獲贊 11 · 訪問量 77萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章