drupal7的cache緩存開發(fā)實(shí)例教程
來源:易賢網(wǎng) 閱讀:1158 次 日期:2016-07-01 09:11:38
溫馨提示:易賢網(wǎng)小編為您整理了“drupal7的cache緩存開發(fā)實(shí)例教程”,方便廣大網(wǎng)友查閱!

本文實(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)的頁面的時(shí)候,復(fù)雜的數(shù)據(jù)庫查詢,與高花銷的計(jì)算會(huì)導(dǎo)致頁面性能方面的問題。

解決方案之一是在druapl的后臺(tái)頁面開啟頁面緩存。頁面緩存開啟后,可以在某些頁面極大的降低數(shù)據(jù)庫查詢次數(shù)從而提高頁面性能。但是這有一定的局限性,就是頁面緩存僅僅對(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ì)算兩次。

下面的簡單例子用來演示這種情況。

代碼如下:

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ì)在一次的頁面加載過程中有效。如果重新訪問該頁面,則會(huì)重新進(jìn)行數(shù)據(jù)的計(jì)算。就是說靜態(tài)變量緩存的數(shù)據(jù)只是暫時(shí)的,沒有長久的存儲(chǔ)起來。下面的代碼,演示如何將復(fù)雜的計(jì)算結(jié)果的數(shù)據(jù)存儲(chǔ)到drupal的cache表中,從而實(shí)現(xiàn)長久存儲(chǔ)的目的。

代碼如下:

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ù)庫查詢,有一次提升代碼執(zhí)行的效率。

緩存數(shù)據(jù)更新

如果使用cache_set()方式設(shè)置的cache數(shù)據(jù)過期了怎么辦?默認(rèn)情況下,cache_set設(shè)置的緩存會(huì)一直存儲(chǔ)在數(shù)據(jù)庫中,直到你調(diào)用cache_clear_all()函數(shù)進(jìn)行強(qiáng)制清空緩存(如果安裝了admin_menu模塊,使用admin menu提供的清空緩存功能也可以清除cache表的緩存)。

如果你的數(shù)據(jù)是比較零散的更新,可以在每次數(shù)據(jù)更新的時(shí)候,調(diào)用

代碼如下:

cache_clear_all('my_module_data', 'cache')進(jìn)行緩存數(shù)據(jù)的更新。如果是存儲(chǔ)的一些有規(guī)律的數(shù)據(jù)片段,可以通過如下方式使用通配符的方式進(jìn)行清空緩存。

代碼如下:

cache_clear_all('my_module', 'cache', true);

這種方式會(huì)清空所有以my_module為開頭的緩存。

如果你的緩存的過期時(shí)間是有規(guī)律的,可以預(yù)測的,可以嘗試使用下面方式來給緩存設(shè)置過期時(shí)間。

代碼如下:

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)其緩存控制策略。

最簡單,最drupal化的定制自定義緩存表的方式,是在模塊的install文件里執(zhí)行hook_schema().以下是例子:

代碼如下:

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ù)庫查詢一條結(jié)果,將一條結(jié)果寫入數(shù)據(jù)庫,這些都是很輕的操作,沒必要使用緩存。推薦使用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)查看網(wǎng)頁制作
易賢網(wǎng)手機(jī)網(wǎng)站地址:drupal7的cache緩存開發(fā)實(shí)例教程
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國考·省考課程試聽報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)