ThinkPHP实现静态缓存和动态缓存的方法

墨辰丷
Lepaskan: 2023-03-27 16:00:01
asal
1966 orang telah melayarinya

本篇文章主要介绍了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 字符串方式
   '静态地址'  =>   '静态规则', 
)
Salin selepas log masuk


静态缓存文件的根目录在HTML_PATH定义的路径下面,并且只有定义了静态规则的操作才会进行静态缓存。 并且静态缓存支持不同的存储类型。 静态缓存仅在GET请求下面有效。

静态地址

全局的操作静态规则


'read'=>array('{id}',60)//定义所有的read操作的静态规则
Salin selepas log masuk


定义全局的控制器静态规则


'user:'=>array('User/{:action}_{id}','600')//定义所有的User控制器的静态规则
Salin selepas log masuk


定义某个控制器的操作的静态规则//定义Blog控制器的read操作进行静态缓存


'blog:read'=>array('{id}',0)//参数为0表示永久缓存
Salin selepas log masuk


定义全局的静态缓存规则


'*'=>array('{$_SERVER.REQUEST_URI|md5}')//这个属于特殊情况下的使用,任何模块的操作都适用
Salin selepas log masuk


静态规则

静态规则是用于定义要生成的静态文件的名称,静态规则的定义要确保不会冲突。

使用系统变量


{$_×××|function}//_GET、_REQUEST、_SERVER、_SESSION、_COOKIE
{$_GET.name} 
{$_SERVER.REQUEST_URI|md5}
Salin selepas log masuk


使用框架自定义的变量

复制代码 代码如下:


{:module}/{:controller}_{:action}//{:module} 、{:controller} 和{:action}分别表示当前模块名、控制器名和操作名。


使用_GET变量


{var|function}//{id}其实等效于 {$_GET.id}
Salin selepas log masuk


直接使用函数


{|function}//{|time},time函数获取时间后作为文件名称
Salin selepas log masuk


混合定义


'{id},{name|md5}' //在{}之外的字符作为字符串对待,如果包含有"/",会自动创建目录。
{:module}/{:action}_{id}//会在静态目录下面创建模块名称的子目录,然后写入操作名_id.shtml 文件。
Salin selepas log masuk


动态缓存

[S方法数据缓存]

缓存初始化


S(array('type'=>'xcache','expire'=>60));
Salin selepas log masuk


系统目前已经支持的缓存类型包括: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条缓存数据。
Salin selepas log masuk


读取缓存


$value = S('name');//如果缓存标识不存在或者已经过期,则返回false,否则返回缓存值。
Salin selepas log masuk


删除缓存


S('name',null);
Salin selepas log masuk


注意:使用每种缓存时,需要ThinkPHP加载对应的驱动文件,并设置好对应的配置。

使用实例


$user = M('User');
$value = S('list');
if (empty($value)) {
  $list = $user->select();
  S('list', $list, 3600);
  echo '这个是直接从数据库中读取的文件';
  dump($list);
} else {
  echo '这个是缓存文件';
  dump($value);
}
Salin selepas log masuk


[快速缓存]

系统还提供了一个快速缓存方法F可以用来更快的操作,但是,F方法没有有效期,F方法可以支持不同的存储类型,如果是文件类型的话,默认保存在DATA_PATH目录下面。

快速缓存Data数据


F('data',$Data);
F('data',$Data,TEMP_PATH);//快速缓存Data数据,保存到指定的目录
F('User/data',$Data);//F方法支持自动创建缓存子目录,在DATA_PATH目录下面缓存data数据,如果User子目录不存在,则自动创建。
Salin selepas log masuk


获取缓存数据


$Data = F('data');
Salin selepas log masuk


删除缓存数据


F('data',NULL);
Salin selepas log masuk


[查询缓存]

查询缓存功能支持所有的数据库,并且支持所有的缓存方式和有效期。

在使用查询缓存的时候,只需要调用Model类的cache方法。


$Model->cache(true)->where('status=1')->select();
Salin selepas log masuk


如果使用了cache(true),则在查询的同时会根据当前的查询条件等信息生成一个带有唯一标识的查询缓存,如果指定了key的话,则直接生成名称为key的查询缓存。


$Model->cache('cache_name')->select();
Salin selepas log masuk


默认情况下缓存方式采用DATA_CACHE_TYPE参数设置的缓存方式(系统默认值为File表示采用文件方式缓存),缓存有效期是DATA_CACHE_TIME参数设置的时间,也可以单独制定查询缓存的缓存方式和有效期。


$Model->cache(true,60,'xcache')->select();
Salin selepas log masuk


如果指定了查询缓存的key的话,则可以在外部通过S方法直接获取查询缓存的内容。


$value = S('cache_name');
Salin selepas log masuk


除了select方法之外,查询缓存还支持find和getField方法,以及他们的衍生方法(包括统计查询和动态查询方法)。


$Model->where($map)->cache('key',60)->find();
Salin selepas log masuk


本文主要来自官方文档,如有问题可参见ThinkPHP3.2官方文档-缓存

以上就是本文的全部内容,希望对大家的学习有所帮助。


相关推荐:

PHPMyAdmin导入时提示文件大小超出PHP限制的解决方法_javascript技巧

php常见的页面跳转方法汇总_javascript技巧

PHP和NodeJs开发的应用如何共用Session_node.js

Atas ialah kandungan terperinci ThinkPHP实现静态缓存和动态缓存的方法. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan