drupal7的cache缓存开发实例教程
2016-07-01来源:

本文实例讲述了drupal7的cache缓存开发的方法。分享给大家供大家参考。具体方法如下:

drupal是一款非常好用的php开发的开源内容管理框架了,这个框架在缓存方面做得非常的不错,下文一起来学习drupal7 cache缓存开发吧。

使用drupal构建复杂而动态的内容是件很容易的事情。但是稍有不慎,你会为这种容易付出代价。在用户查看某些复杂而动态的页面的时候,复杂的数据库查询,与高花销的计算会导致页面性能方面的问题。

解决方案之一是在druapl的后台页面开启页面缓存。页面缓存开启后,可以在某些页面极大的降低数据库查询次数从而提高页面性能。但是这有一定的局限性,就是页面缓存仅仅对匿名用户有效。对应登录用户则会生效。

逐渐的,你可能会分析自己写过的代码,找出数据出查询的热点进行缓存优化。幸运的是,drupal已经内置了一些缓存api,如果遵循下面的一些规则,可以将你的代码优化工作变得更容易。

基本规则:

规则:如果计算结果可以重用或存储,就不要计算两次。

下面的简单例子用来演示这种情况。

代码如下:

function my_module_function() {

$my_data = &drupal_static(__function__);

if (!isset($my_data)) {

//将一些高花销的计算逻辑写在这里,并将结果赋值给$my_data变量。

}

return $my_data;

}

理解上面的的代码,需要一定的php基础知识。

首先是知道php有个变量类型是静态变量(static)。drupal_static函数其实就是实现static变量的集中管理。

其次是函数前加&符号,这种是按址传值。这样的话,对$my_data变量的任何更改,对&drupal_static(__function__)都会相应更改。

这两点理解后再来看上面的逻辑,发现虽然只有一个if判断,但其实这段代码是精妙无比的。

进阶:善用drupal的cache函数。

在上面的代码中,静态变量的数据只会在一次的页面加载过程中有效。如果重新访问该页面,则会重新进行数据的计算。就是说静态变量缓存的数据只是暂时的,没有长久的存储起来。下面的代码,演示如何将复杂的计算结果的数据存储到drupal的cache表中,从而实现长久存储的目的。

代码如下:

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 {

//将一些高花销的计算逻辑写在这里,并将结果赋值给$my_data变量。

//这里将计算的结果保存到cache表中。

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

}

}

return $my_data;

}

上面的例子,结合了cache_set与cache_get,对计算出的结果数据缓存到drupal的cache表中;在第一次执行的时候,需要复杂计算;但是第二次执行这段代码的时候,数据内容会直接从cache表中读取,从而避免复杂的计算开销或数据库查询,有一次提升代码执行的效率。

缓存数据更新

如果使用cache_set()方式设置的cache数据过期了怎么办?默认情况下,cache_set设置的缓存会一直存储在数据库中,直到你调用cache_clear_all()函数进行强制清空缓存(如果安装了admin_menu模块,使用admin menu提供的清空缓存功能也可以清除cache表的缓存)。

如果你的数据是比较零散的更新,可以在每次数据更新的时候,调用

代码如下:

cache_clear_all('my_module_data', 'cache')进行缓存数据的更新。如果是存储的一些有规律的数据片段,可以通过如下方式使用通配符的方式进行清空缓存。

代码如下:

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

这种方式会清空所有以my_module为开头的缓存。

如果你的缓存的过期时间是有规律的,可以预测的,可以尝试使用下面方式来给缓存设置过期时间。

代码如下:

cache_set('my_module_data', $my_data, 'cache', time() + 3600);

最后一个参数是unix时间戳,表示是缓存的过期时间。在这个例子中,缓存在设置的一个小时后过期,缓存中的数据自动被丢弃。

定制自己的缓存表

在上面的代码展示过程中,如果你细心,你会发现cache_set()函数的第三个参数cache,这个其实是代表cache的数据表的名字。如果你需要使用大量的缓存,最好可以使用一个独立的数据表来存数缓存数据;这样有利于加速数据查询的速度。大名鼎鼎的views模块就使用了这种技术来实现其缓存控制策略。

最简单,最drupal化的定制自定义缓存表的方式,是在模块的install文件里执行hook_schema().以下是例子:

代码如下:

function mymodule_schema() {

$schema['cache_mymodule'] = drupal_get_schema_unprocessed('system', 'cache');

return $schema;

}

上面的函数中的drupal_get_schema_unprocessed('system', 'cache')用来获取drupal默认的cache表结构的定义供cache_mymodule表使用。

如果你想彻底压榨服务器的性能,只要在settings.php文件里添加少量代码,就可以让drupal cache_set,cache_get等函数调用的cache系统用其他的缓存系统来替换。比如广受欢迎的memcache(基于内存的缓存,效率极高),apc(基于文件的缓存)等。只要使用标准的drupal cache函数,即使更改了缓存系统,也不需要修改你的代码。

一些注意点:

1. 切勿为了缓存而缓存。比如从数据库查询一条结果,将一条结果写入数据库,这些都是很轻的操作,没必要使用缓存。推荐使用devel模块来查找代码方面性能瓶颈并进行针对性的优化。

2. 缓存表存数的数据都是blob类型的,切勿做与cache表的join查询。

3. 切记缓存中的数据不是永久存储的。任何调用cache_clear_all的代码都会清空缓存。因此无法通过重复计算获取的数据,切勿存储到缓存表。

希望本文所述对大家的drupal建站有所帮助。

推荐信息
Baidu
map