ThinkPHP实现缓存
静态缓存
要使用静态缓存功能,需要开启 HTML_CACHE_ON 参数,并且使用 HTML_CACHE_RULES 配置参数设置静态缓存规则文件。
定义静态规则
'HTML_CACHE_ON' => true, // 开启静态缓存 'HTML_CACHE_TIME' => 60, // 全局静态缓存有效期(秒) 'HTML_FILE_SUFFIX' => '.shtml', // 设置静态缓存文件后缀 'HTML_CACHE_RULES' => array( // 定义静态缓存规则 // 定义格式1 数组方式 '静态地址' => array('静态规则', '有效期', '附加规则'), // 定义格式2 字符串方式 '静态地址' => '静态规则', ) 静态缓存文件的根目录在 HTML_PATH 定义的路径下面,并且只有定义了静态规则的操作才会进行静态缓存。 并且静态缓存支持不同的存储类型。 静态缓存仅在 GET 请求下面有效。 静态地址
全局的操作静态规则
'read'=>array('{id}',60) //定义所有的 read 操作的静态规则
定义全局的控制器静态规则
'user:'=>array('User/{:action}_{id}','600') //定义所有的 User 控制器的静态规则
定义某个控制器的操作的静态规则 //定义 Blog 控制器的 read 操作进行静态缓存
'blog:read'=>array('{id}',0) //参数为0表示永久缓存
定义全局的静态缓存规则
'*'=>array('{$_SERVER.REQUEST_URI|md5}') //这个属于特殊情况下的使用,任何模块的操作都适用
静态规则
静态规则是用于定义要生成的静态文件的名称,静态规则的定义要确保不会冲突。
使用系统变量
{$_×××|function} //_GET、_REQUEST、_SERVER、_SESSION、_COOKIE {$_GET.name} {$_SERVER.REQUEST_URI|md5}
使用框架自定义的变量
复制代码 代码如下:
{: module }/{: controller }_{: action } //{: module } 、{: controller } 和{: action }分别表示当前模块名、控制器名和操作名。
使用 _GET 变量
{var|function}//{id} 其实等效于 {$_GET.id}
直接使用函数
{| function }//{ |time },time 函数获取时间后作为文件名称
混合定义
'{id },{name|md5}' //在{}之外的字符作为字符串对待,如果包含有"/",会自动创建目录。 {:module }/{:action }_{ id } //会在静态目录下面创建模块名称的子目录,然后写入操作名_id.shtml 文件。
动态缓存
[S方法数据缓存]
缓存初始化
S(array('type'=>'xcache','expire'=>60 ));
系统目前已经支持的缓存类型包括: Apachenote 、 Apc 、 Db 、 Eaccelerator 、 File 、 Memcache 、 Redis 、 Shmop 、 Sqlite 、 Wincache 和 Xcache 。如果 S 方法不传入 type 参数初始化的话,则读取配置文件中设置的 DATA_CACHE_TYPE 参数值作为默认类型。同样的道理,prefix 参数如果没有传入会读取配置文件的 DATA_CACHE_PREFIX 参数值,expire 参数没有传入则读取DATA_CACHE_TIME 配置值作为默认。
对于全局的缓存方式,一般我们建议添加 prefix(缓存前缀)参数用以区分不同的应用,以免混淆。
设置缓存
数据缓存可以支持缓存队列,简单的说就是可以限制缓存的数量,只需要在初始化的时候指定 length 参数。
S('name',$value); S('name',$value,300);//缓存数据300秒 S('name',$value,array('type'=>'file','expire'=>300));//改变之前的缓存方式或者更多的参数 S(array('type'=>'xcache','length'=>100,'expire'=>60));//系统只会缓存最近的100条缓存数据。
读取缓存
$value = S('name');//如果缓存标识不存在或者已经过期,则返回 false,否则返回缓存值。
删除缓存
S('name',null);
注意:使用每种缓存时,需要 ThinkPHP 加载对应的驱动文件,并设置好对应的配置。
使用实例
$user = M('User'); $value = S('list'); if (empty($value)) { $list = $user->select(); S('list', $list, 3600); echo '这个是直接从数据库中读取的文件'; dump($list); } else { echo '这个是缓存文件'; dump($value); }
[快速缓存]
系统还提供了一个快速缓存方法 F 可以用来更快的操作,但是,F 方法没有有效期,F 方法可以支持不同的存储类型,如果是文件类型的话,默认保存在 DATA_PATH 目录下面。
快速缓存 Data 数据
F('data',$Data); F('data',$Data,TEMP_PATH);//快速缓存Data数据,保存到指定的目录 F('User/data',$Data);//F方法支持自动创建缓存子目录,在DATA_PATH目录下面缓存data数据,如果User子目录不存在,则自动创建。
获取缓存数据
$Data = F('data');
删除缓存数据
F('data',NULL);
[查询缓存]
查询缓存功能支持所有的数据库,并且支持所有的缓存方式和有效期。
在使用查询缓存的时候,只需要调用Model类的cache方法。
$Model->cache(true)->where('status=1')->select();
如果使用了cache(true),则在查询的同时会根据当前的查询条件等信息生成一个带有唯一标识的查询缓存,如果指定了key的话,则直接生成名称为key的查询缓存。
$Model->cache('cache_name')->select();
默认情况下缓存方式采用DATA_CACHE_TYPE参数设置的缓存方式(系统默认值为File表示采用文件方式缓存),缓存有效期是DATA_CACHE_TIME参数设置的时间,也可以单独制定查询缓存的缓存方式和有效期。
$Model->cache(true,60,'xcache')->select();
如果指定了查询缓存的 key 的话,则可以在外部通过 S 方法直接获取查询缓存的内容。
$value = S('cache_name');
除了select方法之外,查询缓存还支持 find 和 getField 方法,以及他们的衍生方法(包括统计查询和动态查询方法)。
$Model->where($map)->cache('key',60)->find();
本文主要来自官方文档,如有问题可参见 ThinkPHP3.2 官方文档-缓存