1、普遍緩存技術(shù):
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供大田網(wǎng)站建設(shè)、大田做網(wǎng)站、大田網(wǎng)站設(shè)計、大田網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、大田企業(yè)網(wǎng)站模板建站服務(wù),10多年大田做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。
數(shù)據(jù)緩存:這里所說的數(shù)據(jù)緩存是指數(shù)據(jù)庫查詢PHP緩存機制,每次訪問頁面的時候,都會先檢測相應(yīng)的緩存數(shù)據(jù)是否存在,如果不存在,就連接數(shù)據(jù)庫,得到數(shù)據(jù),并把查詢結(jié)果序列化后保存到文件中,以后同樣的查詢結(jié)果就直接從緩存表或文件中獲得。
用的最廣的例子看Discuz的搜索功能,把結(jié)果ID緩存到一個表中,下次搜索相同關(guān)鍵字時先搜索緩存表。
舉個常用的方法,多表關(guān)聯(lián)的時候,把附表中的內(nèi)容生成數(shù)組保存到主表的一個字段中,需要的時候數(shù)組分解一下,這樣的好處是只讀一個表,壞處就是兩個數(shù)據(jù)同步會多不少步驟,數(shù)據(jù)庫永遠是瓶頸,用硬盤換速度,是這個的關(guān)鍵點。
2、 頁面緩存:
每次訪問頁面的時候,都會先檢測相應(yīng)的緩存頁面文件是否存在,如果不存在,就連接數(shù)據(jù)庫,得到數(shù)據(jù),顯示頁面并同時生成緩存頁面文件,這樣下次訪問的時候頁面文件就發(fā)揮作用了。(模板引擎和網(wǎng)上常見的一些PHP緩存機制類通常有此功能)
3、 時間觸發(fā)緩存:
檢查文件是否存在并且時間戳小于設(shè)置的過期時間,如果文件修改的時間戳比當前時間戳減去過期時間戳大,那么就用緩存,否則更新緩存。
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)容是服務(wù)器端的緩存方案,非代碼級的,要有多方的合作才能做到
6、 內(nèi)存緩存:
Memcached是高性能的,分布式的內(nèi)存對象PHP緩存機制系統(tǒng),用于在動態(tài)應(yīng)用中減少數(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)
thinkPHP的F方法只能用于緩存簡單數(shù)據(jù)類型,不支持有效期和緩存對象。S()緩存方法支持有效期,又稱動態(tài)緩存方法,使用示例如下:
復(fù)制代碼代碼如下:
// 使用data標識緩存$Data數(shù)據(jù)
S('data',$Data); //前面的是緩存標示,后面的是緩存的數(shù)據(jù)
復(fù)制代碼代碼如下:
// 緩存$Data數(shù)據(jù)3600秒
S('data',$Data,3600);
復(fù)制代碼代碼如下:
// 刪除緩存數(shù)據(jù)
S('data',NULL); //第一個參數(shù)時緩存的標識名
復(fù)制代碼代碼如下:
$cache=S($cachename);//設(shè)置緩存標示
// 判斷是否有這個查詢緩存
if(!$cache){ //$cache 中是緩存的標示(每個查詢都對應(yīng)一個緩存 即 不同的查詢有不同的緩存)
$cache=$video-where($map)-order($order)-limit($limit)-select();
foreach($cache as $key=$value){
$userlist=$user-where("id=".$value['user_id'])-find();
$cache[$key]["nickname"]=$userlist['nickname'];
}
S($cachename,$cache,3600); //設(shè)置緩存的生存時間
}
S($cachename,NULL); //刪除緩存
看你的具體需求是怎樣的了,
eaccelerator.,
xcache
等
還有一種就是文件緩存
這種一般是
用php自己實現(xiàn)的
沒什么可說的一種是對
頁面結(jié)果的緩存
應(yīng)用服務(wù)器級別的
軟件如
squid
一種是
內(nèi)存級別的
一般是對
php
頻繁調(diào)用的并且如果每次查詢會消耗大量資源的數(shù)據(jù)
軟件有
memcached
一種是
對php
程序進行優(yōu)化編碼的緩存
如
apache
里面的
apc
PHP靜態(tài)文件生成方法:
ob_start();????//開啟緩存????????????????????????
require_once('./templates/moban.php');?//導(dǎo)入模板文件(頁面)
file_put_contents('index.html',ob_get_contents());?//生成靜態(tài)文件index.html
本文實例講述了php的文件緩存類。分享給大家供大家參考。具體分析如下:
緩存類是我們開發(fā)應(yīng)用中會常用使用到的功能,下面就來給大家整理幾個php文件緩存類了,各個文件緩存類寫法不同,但在性能上會有區(qū)別,有興趣測試的朋友可測試一下這些緩存類。
例1
復(fù)制代碼
代碼如下:?php
$fzz
=
new
fzz_cache;
$fzz-kk
=
$_SERVER;
//寫入緩存
//$fzz-set("kk",$_SERVER,10000);
//此方法不與類屬性想沖突,可以用任意緩存名;
print_r($fzz-kk);
//讀取緩存
//print_r($fzz-get("kk"));
//unset($fzz-kk);
//刪除緩存
//$fzz-_unset("kk");
var_dump(isset($fzz-kk));
//判斷緩存是否存在
//$fzz-_isset("kk");
//$fzz-clear();
//清理過期緩存
//$fzz-clear_all();
//清理所有緩存文件
class
fzz_cache{
public
$limit_time
=
20000;
//緩存過期時間
public
$cache_dir
=
"data";
//緩存文件保存目錄
//寫入緩存
function
__set($key
,
$val){
$this-_set($key
,$val);
}
//第三個參數(shù)為過期時間
function
_set($key
,$val,$limit_time=null){
$limit_time
=
$limit_time
?
$limit_time
:
$this-limit_time;
$file
=
$this-cache_dir."/".$key.".cache";
$val
=
serialize($val);
@file_put_contents($file,$val)
or
$this-error(__line__,"fail
to
write
in
file");
@chmod($file,0777);
@touch($file,time()+$limit_time)
or
$this-error(__line__,"fail
to
change
time");
}
//讀取緩存
function
__get($key){
return
$this-_get($key);
}
function
_get($key){
$file
=
$this-cache_dir."/".$key.".cache";
if
(@filemtime($file)=time()){
return
unserialize(file_get_contents($file));
}else{
@unlink($file)
or
$this-error(__line__,"fail
to
unlink");
return
false;
}
}
//刪除緩存文件
function
__unset($key){
return
$this-_unset($key);
}
function
_unset($key){
if
(@unlink($this-cache_dir."/".$key.".cache")){
return
true;
}else{
return
false;
}
}
//檢查緩存是否存在,過期則認為不存在
function
__isset($key){
return
$this-_isset($key);
}
function
_isset($key){
$file
=
$this-cache_dir."/".$key.".cache";
if
(@filemtime($file)=time()){
return
true;
}else{
@unlink($file)
;
return
false;
}
}
//清除過期緩存文件
function
clear(){
$files
=
scandir($this-cache_dir);
foreach
($files
as
$val){
if
(filemtime($this-cache_dir."/".$val)time()){
@unlink($this-cache_dir."/".$val);
}
}
}
//清除所有緩存文件
function
clear_all(){
$files
=
scandir($this-cache_dir);
foreach
($files
as
$val){
@unlink($this-cache_dir."/".$val);
}
}
function
error($msg,$debug
=
false)
{
$err
=
new
Exception($msg);
$str
=
"pre
span
style='color:red'error:/span
".print_r($err-getTrace(),1)."
/pre";
if($debug
==
true)
{
file_put_contents(date('Y-m-d
H_i_s').".log",$str);
return
$str;
}else{
die($str);
}
}
}
?
一、全頁面靜態(tài)化緩存
也就是將頁面全部生成html靜態(tài)頁面,用戶訪問時直接訪問的靜態(tài)頁面,而不會去走php服務(wù)器解析的流程。此種方式,在CMS系統(tǒng)中比較常見,比如dedecms;
一種比較常用的實現(xiàn)方式是用輸出緩存:
Ob_start()******要運行的代碼*******$content=Ob_get_contents();****將緩存內(nèi)容寫入html文件*****Ob_end_clean();
二、數(shù)據(jù)緩存
顧名思義,就是緩存數(shù)據(jù)的一種方式;比如,商城中的某個商品信息,當用商品id去請求時,就會得出包括店鋪信息、商品信息等數(shù)據(jù),此時就可以將這些數(shù)據(jù)緩存到一個php文件中,文件名包含商品id來建一個唯一標示;下一次有人想查看這個商品時,首先就直接調(diào)這個文件里面的信息,而不用再去數(shù)據(jù)庫查詢;其實緩存文件中緩存的就是一個php數(shù)組之類;
Ecmall商城系統(tǒng)里面就用了這種方式;
三、查詢緩存
其實這跟數(shù)據(jù)緩存是一個思路,就是根據(jù)查詢語句來緩存;將查詢得到的數(shù)據(jù)緩存在一個文件中,下次遇到相同的查詢時,就直接先從這個文件里面調(diào)數(shù)據(jù),不會再去查數(shù)據(jù)庫;但此處的緩存文件名可能就需要以查詢語句為基點來建立唯一標示;
按時間變更進行緩存
就是對于緩存文件您需要設(shè)一個有效時間,在這個有效時間內(nèi),相同的訪問才會先取緩存文件的內(nèi)容,但是超過設(shè)定的緩存時間,就需要重新從數(shù)據(jù)庫中獲取數(shù)據(jù),并生產(chǎn)最新的緩存文件;比如,我將我們商城的首頁就是設(shè)置2個小時更新一次。
四、頁面部分緩存
該種方式,是將一個頁面中不經(jīng)常變的部分進行靜態(tài)緩存,而經(jīng)常變化的塊不緩存,最后組裝在一起顯示;可以使用類似于ob_get_contents的方式實現(xiàn),也可以利用類似ESI之類的頁面片段緩存策略,使其用來做動態(tài)頁面中相對靜態(tài)的片段部分的緩存。
該種方式可以用于如商城中的商品頁;
五、Opcode緩存
首先php代碼被解析為Tokens,然后再編譯為Opcode碼,最后執(zhí)行Opcode碼,返回結(jié)果;所以,對于相同的php文件,第一次運行時可以緩存其Opcode碼,下次再執(zhí)行這個頁面時,直接會去找到緩存下的opcode碼,直接執(zhí)行最后一步,而不再需要中間的步驟了。
比較知名的是XCache、TurckMMCache、PHPAccelerator等。
六、按內(nèi)容變更進行緩存
這個也并非獨立的緩存技術(shù),需結(jié)合著用;就是當數(shù)據(jù)庫內(nèi)容被修改時,即刻更新緩存文件;
比如,一個人流量很大的商城,商品很多,商品表必然比較大,這表的壓力也比較重;我們就可以對商品顯示頁進行頁面緩存;
當商家在后臺修改這個商品的信息時,點擊保存,我們同時就更新緩存文件;那么,買家訪問這個商品信息時,實際問的是一個靜態(tài)頁面,而不需要再去訪問數(shù)據(jù)庫;
試想,如果對商品頁不緩存,那么每次訪問一個商品就要去數(shù)據(jù)庫查一次,如果有10萬人在線瀏覽商品,那服務(wù)器壓力就大了;
七、內(nèi)存式緩存
提到這個,可能大家想到的首先就是Memcached;memcached是高性能的分布式內(nèi)存緩存服務(wù)器。一般的使用目的是,通過緩存數(shù)據(jù)庫查詢結(jié)果,減少數(shù)據(jù)庫訪問次數(shù),以提高動態(tài)Web應(yīng)用的速度、提高可擴展性。
它就是將需要緩存的信息,緩存到系統(tǒng)內(nèi)存中,需要獲取信息時,直接到內(nèi)存中取;比較常用的方式就是key_value方式;
connect($memcachehost,$memcacheport)ordie("Couldnotconnect");$memcache-set('key','緩存的內(nèi)容');$get=$memcache-get($key);//獲取信息?
八、apache緩存模塊
apache安裝完以后,是不允許被cache的。云南IT培訓(xùn)認為如果外接了cache或squid服務(wù)器要求進行web加速的話,就需要在htttpd.conf里進行設(shè)置,當然前提是在安裝apache的時候要激活mod_cache的模塊。