ThinkPHP的缓存技术

简介: 原文:ThinkPHP的缓存技术如果没有缓存的网站是百万级或者千万级的访问量,会给数据库或者服务器造成很大的压力,通过缓存,大幅减少服务器和数据库的负荷。假如我们 把读取数据的过程分为三个层,第一个是访问层,第一个是缓存层,第三个是数据库存取层。
原文: ThinkPHP的缓存技术

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

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

 

Thinkphp缓存文件的配置

 

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

 

01 <?php
02 /**
03  * 配置文件
04  */
05  return array(
06  'DB_TYPE'=>'mysql',
07  'DB_HOST'=>'127.0.0.1',
08  'DB_NAME'=>'w3note',
09  'DB_USER'=>'root',
10  'DB_PWD'=>'123456',
11  'DB_PORT'=>'3306',
12  'DB_PREFIX'=>'w3_',
13  'DATA_CACHE_TYPE'=>'file',//设置缓存方式为file
14  'DATA_CACHE_TIME'=>'600',//缓存周期600秒
15  
16  
17 );
18 ?>

 

 

Thinkphp缓存函数的使用

 

在thinkphp中,我喜欢使用快捷缓存函数S()进行缓存; 其用法如下:

 

S('data',$Data);//使用data标识缓存$Data数据

 

S('data',$Data,600);// 缓存$Data数据600秒

 

$Data = S('data');// 获取缓存数据

 

S('data',NULL);// 删除缓存数据

 

下面是是前台项目控制器的完整代码

01 <?php
02 // 本类由系统自动生成,仅供测试用途
03 class IndexAction extends Action{
04     public function index(){
05  
06       //如果有缓存,则读取缓存数据
07       //如果没有缓存,则读取数据库当中的数据放入缓存
08       $lists=S('lists');
09  
10             if(empty($lists)){
11  
12         $news=M('news');
13  
14         $lists=$news->select();
15  
16         S('lists',$lists,600);
17  
18         echo '这是直接读取数据库的数据';
19  
20          }
21  
22       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"
}
...

说明,第一次运行时,会打印出如上面所示信息,刷新一下页面后,少了“ 这是直接读取数据库的数据",说明读取的是先前生成的缓存数据。

目录
相关文章
|
2月前
|
存储 缓存 NoSQL
作者推荐 | 企业级缓存技术解析,你必须知道的“9“大技术问题与常见误区
本文将深入剖析导致上述问题的九大根源,并提供相应的解决方案。请注意,本文以Java为例进行代码演示,但同样适用于其他技术平台的朋友。只需根据相应技术平台替换相关代码即可!
454 0
作者推荐 | 企业级缓存技术解析,你必须知道的“9“大技术问题与常见误区
|
20天前
|
缓存 应用服务中间件 数据库
【分布式技术专题】「缓存解决方案」一文带领你好好认识一下企业级别的缓存技术解决方案的运作原理和开发实战(多级缓存设计分析)
【分布式技术专题】「缓存解决方案」一文带领你好好认识一下企业级别的缓存技术解决方案的运作原理和开发实战(多级缓存设计分析)
26 1
|
1月前
|
存储 NoSQL Redis
陌陌技术分享:陌陌IM在后端KV缓存架构上的技术实践
在本文中,陌陌数据库负责人冀浩东将聚焦探讨陌陌的 KV 系统架构选型思路,深入解析如何进行此类系统的甄选决策,同时进一步分享陌陌团队在采用 OceanBase(OBKV)过程中所经历的探索与实践经验。
31 0
|
5月前
|
缓存 Java Maven
微服务技术系列教程(07) - SpringBoot - 缓存的使用
微服务技术系列教程(07) - SpringBoot - 缓存的使用
43 0
|
9月前
|
存储 缓存 NoSQL
缓存杂谈(一) Redis 横向技术对比
Redis 横向技术对比 简述
65 0
|
4月前
|
缓存 算法
HTTP 缓存技术 - 协商缓存
HTTP 缓存技术 - 协商缓存
44 1
HTTP 缓存技术 - 协商缓存
|
4月前
|
存储 缓存 算法
HTTP 缓存技术 - 强制缓存
HTTP 缓存技术 - 强制缓存
48 0
HTTP 缓存技术 - 强制缓存
|
4月前
|
存储 缓存 前端开发
HTTP 缓存技术 - 认识缓存
HTTP 缓存技术 - 认识缓存
37 0
|
9月前
|
存储 缓存 NoSQL
Redis缓存技术(第一课)(二)
Redis缓存技术(第一课)(二)
83 0
|
6月前
|
存储 缓存 NoSQL
springboot快速整合Memcached缓存技术
springboot快速整合Memcached缓存技术

热门文章

最新文章