前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >thinkphp缓存技术

thinkphp缓存技术

作者头像
PM吃瓜
发布2019-08-13 12:51:41
1.4K0
发布2019-08-13 12:51:41
举报
文章被收录于专栏:PM吃瓜(公众号)

如果没有缓存的网站是百万级或者千万级的访问量,会给数据库或者服务器造成很大的压力,通过缓存,大幅减少服务器和数据库的负荷。假如我们把读取数据的过程分为三个层,第一个是访问层,第一个是缓存层,第三个是数据库存取层。如果没有缓存层,访问层是直接从数据库存取层读取数据,而设置缓存后,访问层不再是直接在数据库存取层读取,而是从缓存层读取数据。

我们做个简单的对比,假设一个页面,在一个小时可被访问100万次,如果这个页面每次被访问的时候,都直接读取数据库后再编译生成,在一个小时内将会重复性的生成100万次;而如果这个页面被周期性的缓存10分钟,也就是每间隔10分钟缓存数据才会被生成一次,一个小时内只会被生成6次,两种方式一对比,效果明显,两种比较下服务器负荷的压力比差别十几万倍以上,缓存技术将使得网站负载在高峰期游刃有余。

thinkphp的缓存方式有许多种,如File、Apachenote、Apc、Eaccelerator、Memcache、Shmop、Sqlite、Db、Redis和Xcache,现在我来说一下File缓存。

Thinkphp缓存文件的配置

Home是我建立的前台项目,在Home\Conf\config.php找到缓存的配置文件,配置如下:

代码语言:javascript
复制
<?php     
代码语言:javascript
复制
/**     
代码语言:javascript
复制
 * 配置文件     
代码语言:javascript
复制
 */
代码语言:javascript
复制
 return array(     
代码语言:javascript
复制
 'DB_TYPE'=>'mysql',     
代码语言:javascript
复制
 'DB_HOST'=>'127.0.0.1',     
代码语言:javascript
复制
 'DB_NAME'=>'w3note',     
代码语言:javascript
复制
 'DB_USER'=>'root',     
代码语言:javascript
复制
 'DB_PWD'=>'123456',     
代码语言:javascript
复制
 'DB_PORT'=>'3306',     
代码语言:javascript
复制
 'DB_PREFIX'=>'w3_',     
代码语言:javascript
复制
 'DATA_CACHE_TYPE'=>'file',//设置缓存方式为file     
代码语言:javascript
复制
 'DATA_CACHE_TIME'=>'600',//缓存周期600秒     
代码语言:javascript
复制
代码语言:javascript
复制
代码语言:javascript
复制
);     
代码语言:javascript
复制
?>Thinkphp缓存函数的使用 在thinkphp中,我喜欢使用快捷缓存函数S()进行缓存; 其用法如下: S('data',$Data);//使用data标识缓存$Data数据 S('data',$Data,600);// 缓存$Data数据600秒 $Data = S('data');// 获取缓存数据 S('data',NULL);// 删除缓存数据 下面是是前台项目控制器的完整代码01<?php     02// 本类由系统自动生成,仅供测试用途     03class IndexAction extends Action{     04    public function index(){     0506      //如果有缓存,则读取缓存数据     07      //如果没有缓存,则读取数据库当中的数据放入缓存     08      $lists=S('lists');     0910            if(empty($lists)){     1112        $news=M('news');     1314        $lists=$news->select();     1516        S('lists',$lists,600);     1718        echo '这是直接读取数据库的数据';     1920         }     2122      dump($list);访问http://127.0.0.1/Home/index.php/Index/index 输出:   这是直接读取数据库的数据       array(10) {  [0] => array(12) {    ["id"] => string(1) "1"    ["catid"] => string(2) "13"    ["title"] => string(4) "thinkphp的缓存技术"    ["content"] => string(8) "thinkphp的缓存技术"    ["tags"] => string(4) "缓存"    ["thumb"] => string(0) ""    ["description"] => string(7) "thinkphp的缓存技术"    ["inputtime"] => string(10) "1348370202"    ["posid"] => string(1) "1"    ["ord"] => string(1) "2"    ["hits"] => string(1) "1"    ["status"] => string(1) "1"  }...        说明,第一次运行时,会打印出如上面所示信息,刷新一下页面后,少了“ 这是直接读取数据库的数据",说明读取的是先前生成的缓存数据。http://w3note.com/index.php/web/30.html
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-03-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Tech爬虫 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档