Drupal7的cache緩存開發(fā)實例教程
來源:易賢網(wǎng) 閱讀:779 次 日期:2015-02-13 13:52:37
溫馨提示:易賢網(wǎng)小編為您整理了“Drupal7的cache緩存開發(fā)實例教程”,方便廣大網(wǎng)友查閱!

本文實例講述了Drupal7的cache緩存開發(fā)的方法。分享給大家供大家參考。具體方法如下:

Drupal是一款非常好用的php開發(fā)的開源內(nèi)容管理框架了,這個框架在緩存方面做得非常的不錯,下文一起來學習Drupal7 cache緩存開發(fā)吧。

使用Drupal構建復雜而動態(tài)的內(nèi)容是件很容易的事情。但是稍有不慎,你會為這種容易付出代價。在用戶查看某些復雜而動態(tài)的頁面的時候,復雜的數(shù)據(jù)庫查詢,與高花銷的計算會導致頁面性能方面的問題。

解決方案之一是在Druapl的后臺頁面開啟頁面緩存。頁面緩存開啟后,可以在某些頁面極大的降低數(shù)據(jù)庫查詢次數(shù)從而提高頁面性能。但是這有一定的局限性,就是頁面緩存僅僅對匿名用戶有效。對應登錄用戶則會生效。

逐漸的,你可能會分析自己寫過的代碼,找出數(shù)據(jù)出查詢的熱點進行緩存優(yōu)化。幸運的是,Drupal已經(jīng)內(nèi)置了一些緩存API,如果遵循下面的一些規(guī)則,可以將你的代碼優(yōu)化工作變得更容易。

基本規(guī)則:

規(guī)則:如果計算結(jié)果可以重用或存儲,就不要計算兩次。

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

復制代碼代碼如下:function my_module_function() {

$my_data = &drupal_static(__FUNCTION__);

if (!isset($my_data)) {

//將一些高花銷的計算邏輯寫在這里,并將結(jié)果賦值給$my_data變量。

}

return $my_data;

}

理解上面的的代碼,需要一定的php基礎知識。

首先是知道php有個變量類型是靜態(tài)變量(static)。drupal_static函數(shù)其實就是實現(xiàn)static變量的集中管理。

其次是函數(shù)前加"&"符號,這種是按址傳值。這樣的話,對$my_data變量的任何更改,對&drupal_static(__FUNCTION__)都會相應更改。

這兩點理解后再來看上面的邏輯,發(fā)現(xiàn)雖然只有一個if判斷,但其實這段代碼是精妙無比的。

進階:善用Drupal的cache函數(shù)。

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

復制代碼代碼如下: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 {

//將一些高花銷的計算邏輯寫在這里,并將結(jié)果賦值給$my_data變量。

//這里將計算的結(jié)果保存到cache表中。

cache_set('my_module_data', $my_data, 'cache');

}

}

return $my_data;

}

上面的例子,結(jié)合了cache_set與cache_get,對計算出的結(jié)果數(shù)據(jù)緩存到Drupal的cache表中;在第一次執(zhí)行的時候,需要復雜計算;但是第二次執(zhí)行這段代碼的時候,數(shù)據(jù)內(nèi)容會直接從cache表中讀取,從而避免復雜的計算開銷或數(shù)據(jù)庫查詢,有一次提升代碼執(zhí)行的效率。

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

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

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

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

復制代碼代碼如下:cache_clear_all('my_module', 'cache', TRUE);

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

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

復制代碼代碼如下:cache_set('my_module_data', $my_data, 'cache', time() + 3600);

最后一個參數(shù)是unix時間戳,表示是緩存的過期時間。在這個例子中,緩存在設置的一個小時后過期,緩存中的數(shù)據(jù)自動被丟棄。

定制自己的緩存表

在上面的代碼展示過程中,如果你細心,你會發(fā)現(xiàn)cache_set()函數(shù)的第三個參數(shù)"cache",這個其實是代表cache的數(shù)據(jù)表的名字。如果你需要使用大量的緩存,最好可以使用一個獨立的數(shù)據(jù)表來存數(shù)緩存數(shù)據(jù);這樣有利于加速數(shù)據(jù)查詢的速度。大名鼎鼎的views模塊就使用了這種技術來實現(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默認的cache表結(jié)構的定義供cache_mymodule表使用。

如果你想徹底壓榨服務器的性能,只要在settings.php文件里添加少量代碼,就可以讓Drupal cache_set,cache_get等函數(shù)調(diào)用的cache系統(tǒng)用其他的緩存系統(tǒng)來替換。比如廣受歡迎的memcache(基于內(nèi)存的緩存,效率極高),APC(基于文件的緩存)等。只要使用標準的Drupal cache函數(shù),即使更改了緩存系統(tǒng),也不需要修改你的代碼。

一些注意點:

1. 切勿為了緩存而緩存。比如從數(shù)據(jù)庫查詢一條結(jié)果,將一條結(jié)果寫入數(shù)據(jù)庫,這些都是很輕的操作,沒必要使用緩存。推薦使用devel模塊來查找代碼方面性能瓶頸并進行針對性的優(yōu)化。

2. 緩存表存數(shù)的數(shù)據(jù)都是blob類型的,切勿做與cache表的join查詢。

3. 切記緩存中的數(shù)據(jù)不是永久存儲的。任何調(diào)用cache_clear_all的代碼都會清空緩存。因此無法通過重復計算獲取的數(shù)據(jù),切勿存儲到緩存表。

希望本文所述對大家的drupal建站有所幫助。

更多信息請查看IT技術專欄

更多信息請查看網(wǎng)頁制作
易賢網(wǎng)手機網(wǎng)站地址:Drupal7的cache緩存開發(fā)實例教程
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢?yōu)闇剩?/div>

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網(wǎng)