thinkphp缓存技术 .

合集下载

thinkphp_cache()用法和场景_解释说明

thinkphp_cache()用法和场景_解释说明

thinkphp cache()用法和场景解释说明1. 引言1.1 概述在现代网站和应用开发中,缓存起着非常重要的作用。

它可以提高系统性能、减轻数据库负载、加快数据访问速度等。

而在thinkphp框架中,我们可以使用`cache()`方法来进行缓存相关操作。

本文将介绍thinkphp中`cache()`方法的基本用法、常见场景应用,以及一些使用技巧和注意事项。

1.2 文章结构本文将分为五个部分进行讲解。

首先是引言部分,介绍文章的背景和结构;其次是thinkphp `cache()`的基本用法,包括缓存读取、写入和删除;然后是常见场景应用,如页面缓存优化、数据查询缓存加速和表单重复提交避免;接下来是使用技巧和注意事项,包括设置缓存有效期、清空所有缓存和指定键名的缓存以及高效利用缓存包装函数和选择合适的驱动类型;最后是结论部分,总结全文并提出思考或建议。

1.3 目的本文旨在帮助读者深入了解thinkphp框架中`cache()`方法的使用,并指导读者在实际项目开发过程中合理地应用缓存技术,以提升系统性能和用户体验。

通过掌握`cache()`方法的基本用法、常见场景应用和使用技巧,读者能够更加灵活地运用缓存机制解决实际问题,并避免一些常见的误区和错误使用。

2. thinkphp cache()的基本用法2.1 缓存读取:thinkphp的缓存读取功能通过调用cache()函数实现。

cache()函数接受一个参数,即要读取缓存的键名。

例如,我们可以使用如下代码来读取名为“user”键的缓存数据:```$data = cache('user');```在上述代码中,cache('user')表示读取名为“user”的缓存数据,并将其赋值给变量$data。

如果成功读取到了缓存数据,则$data变量将包含该数据,否则为空。

2.2 缓存写入:与缓存读取类似,thinkphp的缓存写入功能也是通过cache()函数来实现的。

认识:ThinkPHP的编译缓存文件~runtime.php

认识:ThinkPHP的编译缓存文件~runtime.php

认识:ThinkPHP的编译缓存⽂件~runtime.php1.定义单⼊⼝⽂件(index.php)在单⼊⼝index.php中不定义这两项时,会⽣成编译缓存⽂件~runtime.phpdefine('RUNTIME_PATH','./App/Temp/'); //定义编译⽬录define('APP_DEBUG',TRUE); //开启调试模式上述两⾏不能在index.php中作⽤,则index.php变为1 <?php2define('APP_NAME','App'); //项⽬名称3define('APP_PATH','./App/'); //项⽬路径4include './ThinkPHP/ThinkPHP.php'; //引⼊ThinkPHP核⼼运⾏⽂件5 ?>2.⽣成编译缓存⽂件(~runtime.php)3.复制~runtime.php中的全部内容到index.php中,运⾏效果会和之前⼀样。

~runtime.php中缓存的编译内容,相当于把index.php引导的所有操作全部集成到~runtime.php⽂件中。

有了这个缓存的编译⽂件,index.php在下次运⾏时,不再引导,⽽是直接检测是否存在~runtime.php编译缓存⽂件,如果在,则直接运⾏~runtime.php。

其他详解()项⽬编译机制是指系统第⼀次运⾏的时候会⾃动⽣成核⼼缓存⽂件~runtime.php和项⽬编译缓存⽂件~app.php。

这些编译缓存⽂件把核⼼和项⽬必须的⽂件打包到⼀个⽂件中,并且去掉所有空⽩和注释代码,因为存在⼀个预编译的过程,所以还会进⾏⼀些相关的⽬录检测,对于不存在的⽬录可以⾃动⽣成,这个⾃动⽣成机制后⾯还会提到。

当第⼆次执⾏的时候就会直接载⼊编译过的缓存⽂件,从⽽省去很多IO开销,加快执⾏速度。

ThinkPHP5.1教程67.缓存功能

ThinkPHP5.1教程67.缓存功能

ThinkPHP5.1教程67.缓存功能67.缓存功能学习要点:1.缓存功能本节课我们来学习一下系统提供的缓存功能,实现缓存的写入和读取。

一.缓存功能1.系统内置了很多类型的缓存,除了File,其它均需要结合相关产品;2.我们这里主要演示File文本缓存,其它的需要学习相关产品;3.在app.php中,配置文件cache.php进行缓存配置,可以用::init();//驱动方式'type'=>'File',//缓存保存目录(默认runtime/cache)'path'=>'',//缓存前缀'prefix'=>'',//缓存有效期0表示永久缓存'expire'=>0,4.::set()方法,可以设置一个缓存,然后再runtime/cache查看生成结果;Cache::set('user','Mr.Lee');5.::inc()和::dec()实现缓存数据的自增和自减操作;Cache::inc('num');Cache::inc('price',3);Cache::dec('num');Cache::dec('price',3);6.::has()方法,判断缓存是否存在,返回布尔值;Cache::has('user');7.::get()方法,从缓存中获取到相应的数据,无数据返回null;Cache::get('user');8.::delete()方法,可以删除指定的缓存文件;Cache::rm('user');9.::pull()方法,先获取缓存值,然后再删除掉这个缓存,无数据返回null;Cache::pull('user');10.::clear()方法,可以清除所有缓存;Cache::clear();11.::tag()标签,可以将多个缓存归类到标签中,方便统一管理,比如清除;Cache::tag('tag')->set('user','Mr.Lee');Cache::tag('tag')->set('age',20);Cache::set('user','Mr.Lee');Cache::set('age',20);Cache::tag('tag',['user','age']);Cache::clear('tag');12.助手函数的使用:cache();//设置缓存cache('user','Mr.Lee',3600);//输出缓存echo cache('user');//删除指定缓存cache('user',null);。

PHP缓存技术的多种方法

PHP缓存技术的多种方法
8、 MYSQL 缓存: 这也算非代码级的,经典的数据库就是用的这种方式,看下面的运行 时间,0.09xxx 之类的 9、 基于反向代理的 Web 缓存: 如 Nginx,SQUID,mod_proxy(apache2 以上又分为 mod_proxy 和 mod_cache) 10、 DNS 轮询: BIND 是一款开放源码的 DNS 服务器软件,这个要说起来就大了,自 己搜寻去,大家知道有这个东西就行了。 我知道的有 chinacache 等大站就是这样做的,说简洁点就是多服务 器啦,把同一个页面或文件缓存到不同的服务器上,按南北自动解析到相 关的服务器中。 【PHP 缓存技术的多种方法】
以上内容是代码级的解决方案,下面的内容是服务器端的缓存方案,
到主表的一个字段中,需要的时候数组分解一下,这样的好处是只读一个 非代码级的,要有多方的合作才能做到
表,坏处就是两个数据同步会多不少步骤,数据库永久是瓶颈,用硬盘换
6、 内存缓存:
速度,是这个的关键点。
Memcached 是高性能的,分布式的内存对象 PHP 缓存机制系统,用于
的查询结果就直接从缓存表或文件中获得。
5、 静态缓存:
用的最广的例子看 Discuz 的搜寻功能,把结果 ID 缓存到一个表中,
这里所说的静态缓存是指静态化,直接生成 HTML 或 XML 等文本文件,
下次搜寻相同关键字时先搜寻缓存表。
有更新的时候重生成一次,适合于不太改变的页面,这就不说了。
举个常用的方法,多表关联的`时候,把附表中的内容生成数组保存
2、 页面缓存:
在动态应用中削减数据库负载,提升访问速度。
每次访问页面的时候,都会先检测相应的缓存页面文件是否存在,假
7、 php 的缓冲器:

thinkphp的静态缓存使用方法

thinkphp的静态缓存使用方法

thinkphp的静态缓存使用方法ThinkPHP在数据缓存方面包括文件方式、共享内存方式和数据库方式在内的多种方式进行缓存,通过插件方式还可以增加以后需要的缓存类,让应用开发可以选择更加适合自己的缓存方式,从而有效地提高应用执行效率。

目前已经支持的缓存方式包括:File、Apachenote、Apc、Eaccelerator、Memcache、Shmop、Sqlite、Db、Redis和Xcache。

ThinkPHP内置了静态缓存的功能,并且支持静态缓存的规则定义。

要使用静态缓存功能,需要开启HTML_CACHE_ON参数,并且使用HTML_CACHE_RULES配置参数设置静态缓存规则文件。

静态规则的定义方式如下:静态缓存文件的根目录在HTML_PATH定义的路径下面,并且只有定义了静态规则的操作才会进行静态缓存,注意,静态规则的定义有三种方式:第一种是定义全局的操作静态规则,例如定义所有的read操作的静态规则为其中,{id}表示取$_GET['id']为静态缓存文件名,第二个参数表示缓存60秒第二种是定义全局的模块静态规则,例如定义所有的User模块的静态规则为其中,{:action}表示当前的操作名称静态第三种是定义某个模块的操作的静态规则,例如,我们需要定义Blog模块的read操作进行静态缓存有个别特殊的规则,例如空模块和空操作的静态规则的定义,可以使用下面的方式:第四种方式是定义全局的静态缓存规则,这个属于特殊情况下的使用,任何模块的操作都适用,例如根据当前的URL进行缓存静态规则是用于定义要生成的静态文件的名称,写法可以包括以下情况1、使用系统变量包括_GET_REQUEST_SERVER_SESSION_COOKIE格式:例如:2、使用框架特定的变量例如:{:app}、{:group}、{:module}和{:action}分别表示当前项目名、分组名、模块名和操作名3、使用_GET变量{var|function}也就是说{id}其实等效于{$_GET.id}4、直接使用函数{|function}例如:{|time}5、支持混合定义,例如我们可以定义一个静态规则为:'{id},{name|md5}'在{}之外的字符作为字符串对待,如果包含有”/”,会自动创建目录。

ThinkPHP5框架缓存查询操作分析

ThinkPHP5框架缓存查询操作分析

ThinkPHP5框架缓存查询操作分析本⽂实例讲述了ThinkPHP5框架缓存查询操作。

分享给⼤家供⼤家参考,具体如下:缓存设置与使⽤:1、在\application\config.php中设置如下:'cache' => [// 使⽤复合缓存类型'type' => 'complex',// 默认使⽤的缓存'default' => [// 驱动⽅式'type' => 'File', //!!在这设置换⼈的缓存⽅式// 缓存保存⽬录'path' => CACHE_PATH,],// ⽂件缓存'file' => [// 驱动⽅式'type' => 'file',// 设置不同的缓存保存⽬录'path' => RUNTIME_PATH . 'file/',],// redis缓存'redis' => [// 驱动⽅式'type' => 'redis',// 服务器地址'host' => '127.0.0.1',],],2、控制器中use \think\Cache;3、控制器中使⽤Cache::set('name', 'tom',3600);Cache::get('name');缓存查询:1、简单缓存查询:在任意控制器⾥(若想在model⾥完成数据查询也可以,需使⽤Db类)public function cacheSelect(){$_data = db('表名')->cache(60)->find();dump($_data);//60s内在缓存⾥提取数据,不必再从数据库查询}2、设置指定缓存标识,使查询更有效率,使⽤更加⽅便:public function cacheSelect(){$result = db('表名')->cache('随意字符')->where('id','<', 10)->select();}//cacheKey⽅法为任意控制器的任意⽅法public function cacheKey(){//在其他地⽅直接调⽤查出来的数据,避免再次查询:$data = \think\Cache::get('随意字符');dump($data);}更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》及《》。

ThinkPHP实现一键清除缓存方法

ThinkPHP实现一键清除缓存方法

ThinkPHP实现⼀键清除缓存⽅法很多的开源cms系统都有⼀键清除缓存的功能,缓存是为了减轻服务器的压⼒⽽产⽣的,但是同时有缓存的存在也可能使⼀些数据不能实时更新,对此,我们就来实现⼀个ThinkPHP的清理缓存的功能。

代码如下:ThinkPHP后台执⾏的代码://获取要清楚的⽬录和⽬录所在的绝对路径public function cache(){////前台⽤ajax get⽅式进⾏提交的,这⾥是先判断⼀下if($_POST['type']){//得到传递过来的值$type=$_POST['type'];//将传递过来的值进⾏切割,我是⽤“-”进⾏切割的$name=explode('-', $type);//得到切割的条数,便于下⾯循环$count=count($name);//循环调⽤上⾯的⽅法for ($i=0;$i<$count;$i++){//得到⽂件的绝对路径$abs_dir=dirname(dirname(dirname(dirname(__FILE__))));//组合路径$pa=$abs_dir.'indexRuntime';$runtime=$abs_dir.'indexRuntime~runtime.php';if(file_exists($runtime))//判断⽂件是否存在{unlink($runtime);//进⾏⽂件删除}//调⽤删除⽂件夹下所有⽂件的⽅法$this->rmFile($pa,$name[$i]);}//给出提⽰信息$this->ajaxReturn(1,'清除成功',1);}else{$this->display();}}public function rmFile($path,$fileName){//删除执⾏的⽅法//去除空格$path = preg_replace('/(/){2,}|{}{1,}/','/',$path);//得到完整⽬录$path.= $fileName;//判断此⽂件是否为⼀个⽂件⽬录if(is_dir($path)){//打开⽂件if ($dh = opendir($path)){//遍历⽂件⽬录名称while (($file = readdir($dh)) != false){//逐⼀进⾏删除unlink($path.''.$file);}//关闭⽂件closedir($dh);}}}前台页⾯部分代码如下:<script type="text/javascript" src="__PUBLIC__/admin/js/jquery.js"></script><script type="test/javascript">$(function(){$('#button').click(function(){if(confirm("确认要清除缓存?")){var $type=$('#type').val();var $mess=$('#mess');$.post('__URL__/clear',{type:$type},function(data){alert("缓存清理成功");});}else{return false;}});});</script>。

ThinkPHP3.2开放cache注缓存,过滤非法字符

ThinkPHP3.2开放cache注缓存,过滤非法字符
此国产分布式函数调度框架从用法调用难度用户所需代码量超高并发性能qps控频精确程度支持的中间件类型任务控制方式稳定程度等19个方面全方位超过ce
ThinkPHP3.2开放 cache注缓存,过滤非法字符
打开缓存配置文件 /Application/Common/conf/cache.php源代码如下面:
<?php return array(
//'配置项'=>'配置值' 'LAYOUT_ON' => true, 'HTML_CACHE_ON' => strpos($_SERVER['HTTP_HOST'], '.') !== false, // 开启静态缓存 默觉得 true 本地不开启 'HTML_CACHE_TIME' => 3600, // 全局静态缓存有效期(秒) 'HTML_FILE_SUFFIX' => '.shtml', // 设置静态缓存文件后缀 'HTML_CACHE_RULES' => array(
'*' => array('{:module}/{:controller}/{:action}/{$_SERVER.REQUEST_URI|md5}', 3600, 'trimSW'), ) );
注意:背后的 trimSW是去除全部非 / \w 的字符串,防止输入中文等特殊字符某些系统报错。
函数 trimSW的源代码:
/** * @author default7@ * @description 去除 空格 和非\w 字符串,用于cache 配置 * * @param $str * @param string $emptyValue * * @return mixed|string */ function trimSW($str, $emptyValue = '_empty_'([^\w\/]+)/', '-', $str); if (empty($str)) {
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

thinkphp对缓存技术提供了极大的支持。

memcache是我们最常用到的缓存技术。

那么在thinkphp中如何用到memcache呢?1. 查看官方手册。

[php]view plaincopyprint?1. 所有的缓存方式都被统一使用公共的调用接口,这个接口就是Cache缓存类。

2.3. 缓存类的使用很简单:4.5. $Cache = Cache::getInstance('缓存方式','缓存参数');6.7. 例如,使用Xcache作为缓存方式,缓存有效期60秒。

8.9. $Cache = Cache::getInstance('Xcache',array('expire'=>'60'));10.11. 存取缓存数据12.13. $Cache->set('name','ThinkPHP'); // 缓存name数据14.15. $value = $Cache->get('name'); // 获取缓存的name数据16.17. $Cache->rm('name'); // 删除缓存的name数据以上是官方手册。

我们按照以上方法进行连接。

[php]view plaincopyprint?1. c lass CacheAction extends Action{2. //缓存类3. function index() {4.5. $cache = Cache::getInstance('Memcache',array('expire'=>'60')); //60秒6. $cache->set("name","thinkphp");7. $value = $cache->get("name");8. var_dump($value);9.10. if($value){11. dump($value);12. }else{13.14. echo "wrong";15. }16. }17. }上面的结果,却没有出现。

输出结果为:“ bool(false)11” ,一想,这丫根本没缓存啊,是不是memcache出了点问题,于是我重启memcache服务器,然后用原生态的PHP连接memcache,却能够输出缓存结果啊。

我当时就湿了。

深思过后,我恍然大悟:这丫根本没有连接memcache的ip和端口啊。

于是我又改动,如下:[php]view plaincopyprint?1. c lass CacheAction extends Action{2. //缓存类3. function index() {4.5. $cache = Cache::getInstance('Memcache',array('host'=>'127.0.0.1','port'=>'11211','expire'=>60)); //加上memcache服务器IP和端口以及失效时间6. $cache->set("name","thinkphp");7. $value = $cache->get("name");8. var_dump($value);9. //var_dump($cache);10. if($value){11. dump($value);12. }else{13. echo "wrong";14. }15.16. }17.18. }浏览器输出结果,我又湿了。

我擦。

怎么不稳定啊。

一刷新有结果,一刷新又没了,我当时无语了。

打开以上代码中的[php]view plaincopyprint?1. v ar_dump($cache);直接查看这个cache实例,看输出结果是什么,结果也是断断续续,很不稳定:[php]view plaincopyprint?1. o bject(CacheMemcache)#4 (6) { ["connected:protected"]=> bool(true) ["handler:protected"]=> object(Memcache)#5 (1) { ["connection"]=> resource(16) of type(memcache connection) } ["prefix:protected"]=> string(2) "~@" ["options:protected"]=> array(0) { } ["type:protected"]=> string(7) "EMCACHE" ["expire:protected"]=> int(3600) }以上代码表示已经连上。

继续刷新:[php]view plaincopyprint?1. o bject(CacheMemcache)#4 (6) { ["connected:protected"]=> bool(false) ["handler:protected"]=> object(Memcache)#5 (0) { } ["prefix:protected"]=> string(2) "~@" ["options:protected"]=> array(0) { } ["type:protected"]=> string(7) "EMCACHE" ["expire:protected"]=> int(3600) }我擦。

又连接失败了!我彻底阵亡了!!!2 . 通过百度查找资料,发现这另一种方法,修改配置文件config.php文件,在配置文件中加入:[php]view plaincopyprint?1.2. 'DATA_CACHE_TYPE' => 'Memcache', //默认是file方式进行缓存的,修改为memcache3. 'MEMCACHE_HOST' => 'tcp://127.0.0.1:11211', //memcache服务器地址和端口,这里为本机。

4. 'DATA_CACHE_TIME' => '10', //过期的秒数。

通过以上方法连接服务器后,再用代码进行处理,发现可以用了。

[php]view plaincopyprint?1. c lass CacheAction extends Action{2. //缓存类3. function index() {4.5. $cache = Cache::getInstance(); //修改config.php文件后,里面就不需要填参数了,直接调用,实例化。

6. $cache->set("name","thinkphp");7. $value = $cache->get("name");8. var_dump($cache);9. if($value){10. dump($value);11. }else{12.13. echo "wrong";14. }15.16. }17. }上述结果为正确,且刷新不会错误。

OK ,完美解决。

thinkphp你就不能说清楚点哇。

像MEMCACHE_HOST和DATA_CACHE_TIME在手册中根本就搜索不到。

3 . S( )方法。

在官方手册中,提供了一种便捷的缓存方式S( ):[php]view plaincopyprint?1. S("data","123456",10);2. $data = S('data');3. v ar_dump($data);结果也是正确的。

但是注意的是:这种方式默认是采用file文件方式来缓存。

直接这样输出也是可以得到结果的。

要想采用memcache进行缓存。

也一样在cofig.php加上:[php]view plaincopyprint?1. 'DATA_CACHE_TYPE' => 'Memcache', //默认是file方式进行缓存的,修改为memcache2. 'MEMCACHE_HOST' => 'tcp://127.0.0.1:11211', //memcache服务器地址和端口,这里为本机。

3. 'DATA_CACHE_TIME' => '10', //过期的秒数。

那么就变成用memcache来存储缓存了。

那么我推荐:在config.php配置文件中设定好,用S ( )方法来存储和读取。

更高效。

相关文档
最新文档