本文實(shí)例講述了Drupal7的cache緩存開發(fā)的方法。分享給大家供大家參考。具體方法如下:
Drupal是一款非常好用的php開發(fā)的開源內(nèi)容管理框架了,這個(gè)框架在緩存方面做得非常的不錯(cuò),下文一起來學(xué)習(xí)Drupal7 cache緩存開發(fā)吧。
使用Drupal構(gòu)建復(fù)雜而動(dòng)態(tài)的內(nèi)容是件很容易的事情。但是稍有不慎,你會(huì)為這種容易付出代價(jià)。在用戶查看某些復(fù)雜而動(dòng)態(tài)的頁(yè)面的時(shí)候,復(fù)雜的數(shù)據(jù)庫(kù)查詢,與高花銷的計(jì)算會(huì)導(dǎo)致頁(yè)面性能方面的問題。
解決方案之一是在Druapl的后臺(tái)頁(yè)面開啟頁(yè)面緩存。頁(yè)面緩存開啟后,可以在某些頁(yè)面極大的降低數(shù)據(jù)庫(kù)查詢次數(shù)從而提高頁(yè)面性能。但是這有一定的局限性,就是頁(yè)面緩存僅僅對(duì)匿名用戶有效。對(duì)應(yīng)登錄用戶則會(huì)生效。
逐漸的,你可能會(huì)分析自己寫過的代碼,找出數(shù)據(jù)出查詢的熱點(diǎn)進(jìn)行緩存優(yōu)化。幸運(yùn)的是,Drupal已經(jīng)內(nèi)置了一些緩存API,如果遵循下面的一些規(guī)則,可以將你的代碼優(yōu)化工作變得更容易。
基本規(guī)則:
規(guī)則:如果計(jì)算結(jié)果可以重用或存儲(chǔ),就不要計(jì)算兩次。
下面的簡(jiǎn)單例子用來演示這種情況。
復(fù)制代碼代碼如下:function my_module_function() {
$my_data = &drupal_static(__FUNCTION__);
if (!isset($my_data)) {
//將一些高花銷的計(jì)算邏輯寫在這里,并將結(jié)果賦值給$my_data變量。
}
return $my_data;
}
理解上面的的代碼,需要一定的php基礎(chǔ)知識(shí)。
首先是知道php有個(gè)變量類型是靜態(tài)變量(static)。drupal_static函數(shù)其實(shí)就是實(shí)現(xiàn)static變量的集中管理。
其次是函數(shù)前加"&"符號(hào),這種是按址傳值。這樣的話,對(duì)$my_data變量的任何更改,對(duì)&drupal_static(__FUNCTION__)都會(huì)相應(yīng)更改。
這兩點(diǎn)理解后再來看上面的邏輯,發(fā)現(xiàn)雖然只有一個(gè)if判斷,但其實(shí)這段代碼是精妙無比的。
進(jìn)階:善用Drupal的cache函數(shù)。
在上面的代碼中,靜態(tài)變量的數(shù)據(jù)只會(huì)在一次的頁(yè)面加載過程中有效。如果重新訪問該頁(yè)面,則會(huì)重新進(jìn)行數(shù)據(jù)的計(jì)算。就是說靜態(tài)變量緩存的數(shù)據(jù)只是暫時(shí)的,沒有長(zhǎng)久的存儲(chǔ)起來。下面的代碼,演示如何將復(fù)雜的計(jì)算結(jié)果的數(shù)據(jù)存儲(chǔ)到drupal的cache表中,從而實(shí)現(xiàn)長(zhǎng)久存儲(chǔ)的目的。
復(fù)制代碼代碼如下:function my_module_function() {
$my_data = &drupal_static(__FUNCTION__);
if (!isset($my_data)) {
if ($cache = cache_get('my_module_data')) {
$my_data = $cache->data;
}
else {
//將一些高花銷的計(jì)算邏輯寫在這里,并將結(jié)果賦值給$my_data變量。
//這里將計(jì)算的結(jié)果保存到cache表中。
cache_set('my_module_data', $my_data, 'cache');
}
}
return $my_data;
}
上面的例子,結(jié)合了cache_set與cache_get,對(duì)計(jì)算出的結(jié)果數(shù)據(jù)緩存到Drupal的cache表中;在第一次執(zhí)行的時(shí)候,需要復(fù)雜計(jì)算;但是第二次執(zhí)行這段代碼的時(shí)候,數(shù)據(jù)內(nèi)容會(huì)直接從cache表中讀取,從而避免復(fù)雜的計(jì)算開銷或數(shù)據(jù)庫(kù)查詢,有一次提升代碼執(zhí)行的效率。
緩存數(shù)據(jù)更新
如果使用cache_set()方式設(shè)置的cache數(shù)據(jù)過期了怎么辦?默認(rèn)情況下,cache_set設(shè)置的緩存會(huì)一直存儲(chǔ)在數(shù)據(jù)庫(kù)中,直到你調(diào)用cache_clear_all()函數(shù)進(jìn)行強(qiáng)制清空緩存(如果安裝了admin_menu模塊,使用admin menu提供的清空緩存功能也可以清除cache表的緩存)。
如果你的數(shù)據(jù)是比較零散的更新,可以在每次數(shù)據(jù)更新的時(shí)候,調(diào)用
復(fù)制代碼代碼如下:cache_clear_all('my_module_data', 'cache')進(jìn)行緩存數(shù)據(jù)的更新。如果是存儲(chǔ)的一些有規(guī)律的數(shù)據(jù)片段,可以通過如下方式使用通配符的方式進(jìn)行清空緩存。
復(fù)制代碼代碼如下:cache_clear_all('my_module', 'cache', TRUE);
這種方式會(huì)清空所有以my_module為開頭的緩存。
如果你的緩存的過期時(shí)間是有規(guī)律的,可以預(yù)測(cè)的,可以嘗試使用下面方式來給緩存設(shè)置過期時(shí)間。
復(fù)制代碼代碼如下:cache_set('my_module_data', $my_data, 'cache', time() + 3600);
最后一個(gè)參數(shù)是unix時(shí)間戳,表示是緩存的過期時(shí)間。在這個(gè)例子中,緩存在設(shè)置的一個(gè)小時(shí)后過期,緩存中的數(shù)據(jù)自動(dòng)被丟棄。
定制自己的緩存表
在上面的代碼展示過程中,如果你細(xì)心,你會(huì)發(fā)現(xiàn)cache_set()函數(shù)的第三個(gè)參數(shù)"cache",這個(gè)其實(shí)是代表cache的數(shù)據(jù)表的名字。如果你需要使用大量的緩存,最好可以使用一個(gè)獨(dú)立的數(shù)據(jù)表來存數(shù)緩存數(shù)據(jù);這樣有利于加速數(shù)據(jù)查詢的速度。大名鼎鼎的views模塊就使用了這種技術(shù)來實(shí)現(xiàn)其緩存控制策略。
最簡(jiǎn)單,最Drupal化的定制自定義緩存表的方式,是在模塊的install文件里執(zhí)行hook_schema().以下是例子:
復(fù)制代碼代碼如下:function mymodule_schema() {
$schema['cache_mymodule'] = drupal_get_schema_unprocessed('system', 'cache');
return $schema;
}
上面的函數(shù)中的drupal_get_schema_unprocessed('system', 'cache')用來獲取Drupal默認(rèn)的cache表結(jié)構(gòu)的定義供cache_mymodule表使用。
如果你想徹底壓榨服務(wù)器的性能,只要在settings.php文件里添加少量代碼,就可以讓Drupal cache_set,cache_get等函數(shù)調(diào)用的cache系統(tǒng)用其他的緩存系統(tǒng)來替換。比如廣受歡迎的memcache(基于內(nèi)存的緩存,效率極高),APC(基于文件的緩存)等。只要使用標(biāo)準(zhǔn)的Drupal cache函數(shù),即使更改了緩存系統(tǒng),也不需要修改你的代碼。
一些注意點(diǎn):
1. 切勿為了緩存而緩存。比如從數(shù)據(jù)庫(kù)查詢一條結(jié)果,將一條結(jié)果寫入數(shù)據(jù)庫(kù),這些都是很輕的操作,沒必要使用緩存。推薦使用devel模塊來查找代碼方面性能瓶頸并進(jìn)行針對(duì)性的優(yōu)化。
2. 緩存表存數(shù)的數(shù)據(jù)都是blob類型的,切勿做與cache表的join查詢。
3. 切記緩存中的數(shù)據(jù)不是永久存儲(chǔ)的。任何調(diào)用cache_clear_all的代碼都會(huì)清空緩存。因此無法通過重復(fù)計(jì)算獲取的數(shù)據(jù),切勿存儲(chǔ)到緩存表。
希望本文所述對(duì)大家的drupal建站有所幫助。
更多信息請(qǐng)查看IT技術(shù)專欄