前臺靜態(tài)化:把動態(tài)頁面解析后保存為靜態(tài)頁面
文件緩存:把查詢結(jié)果保存為文件,XML
內(nèi)存緩存:memcache
php緩存器:XCache、eaccelerator等
Memcache是一個高性能的分布式的內(nèi)存對象緩存系統(tǒng),通過在內(nèi)存里維護一個統(tǒng)一的巨大的hash表,它能夠用來存儲各種格式的數(shù)據(jù),包括圖像、視頻、文件以及數(shù)據(jù)庫檢索的結(jié)果等。簡單的說就是將數(shù)據(jù)調(diào)用到內(nèi)存中,然后從內(nèi)存中讀取,從而大大提高讀取速度?! emcache是danga的一個項目,最早是LiveJournal 服務的,最初為了加速 LiveJournal 訪問速度而開發(fā)的,后來被很多大型的網(wǎng)站采用?! emcached是以守護程序方式運行于一個或多個服務器中,隨時會接收客戶端的連接和操作。
XCache 是一個開源的 opcode 緩存器/優(yōu)化器, 這意味著他能夠提高您服務器上的 PHP 性能. 他通過把編譯 PHP 后的數(shù)據(jù)緩沖到共享內(nèi)存從而避免重復的編譯過程, 能夠直接使用緩沖區(qū)已編譯的代碼從而提高速度. 通常能夠提高您的頁面生成速率 2 到5 倍, 降低服務器負載.
******************************************************************************************************************************************************
1、普遍緩存技術(shù):
數(shù)據(jù)緩存:這里所說的數(shù)據(jù)緩存是指數(shù)據(jù)庫查詢PHP緩存機制,每次訪問頁面的時候,都會先檢測相應的緩存數(shù)據(jù)是否存在,如果不存在,就連接數(shù)據(jù)庫,得到數(shù)據(jù),并把查詢結(jié)果序列化后保存到文件中,以后同樣的查詢結(jié)果就直接從緩存表或文件中獲得。
用的最廣的例子看Discuz的搜索功能,把結(jié)果ID緩存到一個表中,下次搜索相同關鍵字時先搜索緩存表。
舉個常用的方法,多表關聯(lián)的時候,把附表中的內(nèi)容生成數(shù)組保存到主表的一個字段中,需要的時候數(shù)組分解一下,這樣的好處是只讀一個表,壞處就是兩個數(shù)據(jù)同步會多不少步驟,數(shù)據(jù)庫永遠是瓶頸,用硬盤換速度,是這個的關鍵點。
2、 頁面緩存:
每次訪問頁面的時候,都會先檢測相應的緩存頁面文件是否存在,如果不存在,就連接數(shù)據(jù)庫,得到數(shù)據(jù),顯示頁面并同時生成緩存頁面文件,這樣下次訪問的時候頁面文件就發(fā)揮作用了。(模板引擎和網(wǎng)上常見的一些PHP緩存機制類通常有此功能)
3、 時間觸發(fā)緩存:
檢查文件是否存在并且時間戳小于設置的過期時間,如果文件修改的時間戳比當前時間戳減去過期時間戳大,那么就用緩存,否則更新緩存。
4、 內(nèi)容觸發(fā)緩存:
當插入數(shù)據(jù)或更新數(shù)據(jù)時,強制更新PHP緩存機制。
5、 靜態(tài)緩存:
這里所說的靜態(tài)緩存是指靜態(tài)化,直接生成HTML或XML等文本文件,有更新的時候重生成一次,適合于不太變化的頁面,這就不說了。
以上內(nèi)容是代碼級的解決方案,我直接CP別的框架,也懶得改,內(nèi)容都差不多,很容易就做到,而且會幾種方式一起用,但下面的內(nèi)容是服務器端的緩存方案,非代碼級的,要有多方的合作才能做到
6、 內(nèi)存緩存:
Memcached是高性能的,分布式的內(nèi)存對象PHP緩存機制系統(tǒng),用于在動態(tài)應用中減少數(shù)據(jù)庫負載,提升訪問速度。
7、 php的緩沖器:
有eaccelerator, apc, phpa,xcache,這個這個就不說了吧,搜索一堆一堆的,自己看啦,知道有這玩意就OK
8、 MYSQL緩存:
這也算非代碼級的,經(jīng)典的數(shù)據(jù)庫就是用的這種方式,看下面的運行時間,0.09xxx之類的
9、 基于反向代理的Web緩存:
如Nginx,SQUID,mod_proxy(apache2以上又分為mod_proxy和mod_cache)
10、 DNS輪詢:
BIND是一款開放源碼的DNS服務器軟件,這個要說起來就大了,自己搜索去,大家知道有這個東西就行了。
我知道的有chinacache等大站就是這樣做的,說簡單點就是多服務器啦,把同一個頁面或文件緩存到不同的服務器上,按南北自動解析到相關的服務器中。
PHP網(wǎng)頁緩存實例
- ob_start():頁面緩存開始的標志,此函數(shù)一下的內(nèi)容直至ob_end_flush()或者ob_end_clean()都保存在頁面緩存中;
- ob_get_contents():用來獲取頁面緩存中的內(nèi)容,獲取到以后呢,我們就可以想怎么處理這些內(nèi)容都行了,過濾字段啦,匹配內(nèi)容啦,都可以~~~ :)
- ob_end_flush():表示頁面緩存結(jié)束。并且經(jīng)我驗證,緩存的內(nèi)容將輸出到當前頁面上,也就是可以顯示緩存內(nèi)容。
用此三個php函數(shù),就可以實現(xiàn)強大的功能。如果數(shù)據(jù)庫查詢量較大,可以用cache來解決這個問題。
首先,設定過期時間,如果要求緩存文件2個小時過期,就可以設定cache_time為3600*2;通過filectime()來獲取緩存文件的創(chuàng)建時間(或 filemtime()獲取修改時間),如果當前時間跟文件的創(chuàng)建時間超過限定的過期時間,就可以通過上面三個函數(shù),首先從數(shù)據(jù)庫中取出數(shù)據(jù),然后開始緩存ob_start(),然后把要生成的頁面的html代碼寫在緩存中,緩存結(jié)束后通過ob_get_contents()獲取到緩存的內(nèi)容,然后通過fwrite把緩存內(nèi)容寫到靜態(tài)頁面html。
如果未過期,直接讀取cache中的靜態(tài)頁面即可,避免了大量的數(shù)據(jù)庫訪問。
?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);
//以下是輸出的內(nèi)容,放在cache_start和cache_end兩個方法之間
for ($i=0;$i5;$i++)
{
echo $i;
sleep(1);
}
cache_end($dir);
?>
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- thinkphp5redis緩存新增方法實例講解
- PHP ob緩存以及ob函數(shù)原理實例解析
- 解決PHP Opcache 緩存刷新、代碼重載出現(xiàn)無法更新代碼的問題
- php加速緩存器opcache,apc,xcache,eAccelerator原理與配置方法實例分析
- PHP利用緩存處理用戶注冊時的郵箱驗證,成功后用戶數(shù)據(jù)存入數(shù)據(jù)庫操作示例
- TP5(thinkPHP框架)實現(xiàn)后臺清除緩存功能示例
- ThinkPHP3.2.3框架Memcache緩存使用方法實例總結(jié)
- PHP使用OB緩存實現(xiàn)靜態(tài)化功能示例
- 簡單實用的PHP文本緩存類實例
- PHP緩存系統(tǒng)APCu擴展的使用