缓存技术之——Yii2性能优化之:缓存依赖
Yii中的缓存依赖,简单来说就是将缓存和另外一个东西绑定在一起,如果另外一个东西发生变化,那么缓存也将发生变化。有点儿类似于JS中的触发事件(但是也不那么像),缓存的变动是依赖的东西所导致的。
依赖可以是文件、数据库、甚至是一些表达式。功能十分强大。
Yii提供了5中依赖方法,我们这里介绍其中的3种常用依赖。
1、文件依赖
顾名思义就是将缓存和文件绑定在一起。如果文件的内容发生变化,那么缓存将会收到影响。(Yii判断的标准是文件的最后修改时间)
我们通过实例来演示一下这个过程。
1、首先获取缓存组件
$cache = \Yii::$app->cache;
2、实例化FileDependency
类(其中文件依赖名字为:fileName
),同时将其赋值给$dependency
变量。这里,我们将缓存和yanying.txt
文件做关联,如果yanying.txt
内容发生变化,那么和之对应的缓存将失效,不能访问。
$dependency = new \yii\caching\FileDependency(['fileName'=>'yanying.txt']);
3、下面我们在缓存中添加一个key
为file_key
,给其的值为hello world
。同时将过期时间设置为3000秒,最后一个参数写上$dependency
依赖。
$cache->add('file_key','hello world',3000,$dependency);
4、在3000秒之内,我们刷新网页。一直可以获取到file_key
的值为hello world
。
$cache->get('file_key'); // hello world
5、这时,我们改变yanying.txt
文件内的值。尽管缓存并没有过期,我们也无法获取到缓存的值。因为依赖的文件发生了变化,缓存即被失效。
var_dump($cache->get('file_key')); // false
2、表达式依赖
表达式依赖是将表达式运算过后的值和缓存捆在一起形成依赖,当表达式值发生变化时候,缓存将受到影响
1、同上获取缓存组件
$cache = \Yii::$app->cache;
2、实例化ExpressionDependency
类(表达式依赖名字为:expression
),同时将其赋值给$dependency
变量。这里,表达式依赖不同于文件依赖,他的expression
所对应的是\Yii::$app->request->get("id")
,是直接get链接中的id值(这里的表达式是php表达式,不只限制于YII代码)。
$dependency = new \yii\caching\ExpressionDependency(['expression'=>'\Yii::$app->request->get("id")']);
3、下面我们在缓存中添加一个key
为file_key
,值为hello world
。同时将其过期时间设置为3000秒之后,最后一个参数写上$dependency
依赖。
$cache->add('file_key','hello world',3000,$dependency);
4、在3000秒之内,我们刷新网页,同上,一直可以获取到file_key
的值为hello world
。
$cache->get('file_key'); // hello world
5、这时,我们改变链接中id
的值。那么:\Yii::$app->request->get("id")
获取到的值即会发生变化,则缓存失效。同时无法获取缓存的值。
var_dump($cache->get('file_key')); // false
3、db依赖
db依赖也是实际生产中最常接触的一种依赖,我们可以将SQL语句直接作为依赖条件。当数据库查询出的内容发生变化时候,缓存即会受到影响。
依此,我们可以通过此方法来判断我们缓存的数据是否需要更新,当数据库有变化内容时候,我们更新缓存。
1、首先还是获取缓存组件
$cache = \Yii::$app->cache;
2、实例化DbDependency
类(db依赖名为:sql)。同时将其赋值给$dependency
变量。其中sql
对应的值是直接可执行的sql语句。
$dependency = new \yii\caching\DbDependency(['sql'=>'SELECT COUNT(*) FROM user']);
3、下面我们在缓存中添加一个key
为file_key
,值为hello world
。同时将其过期时间设置为3000秒之后,最后一个参数写上$dependency
依赖。
$cache->add('file_key','hello world',3000,$dependency);
4、假设数据库数据一直没有发生变化,那么3000秒之内此缓存不会发生任何变化。我们可以通过下面代码直接获取值hello world
.
$cache->get('file_key'); // hello world
5、这时,如果数据库添加了一条新的数据,那么此缓存即将失效,无法获取。这里sql依赖判断标准是查询结果,我们这里使用了记录的条数,你也可以直接使用select * from table
只要结果发生变化,都会影响缓存
var_dump($cache->get('file_key')); // false
这时我们也可以愉快的重新获取数据库值,进行新的缓存啦。
缓存技术之——Yii2性能优化之:缓存依赖的更多相关文章
- MySQL 数据库性能优化之缓存参数优化
在平时被问及最多的问题就是关于 MySQL 数据库性能优化方面的问题,所以最近打算写一个MySQL数据库性能优化方面的系列文章,希望对初中级 MySQL DBA 以及其他对 MySQL 性能优化感兴趣 ...
- Yii2性能优化
https://www.yiiframework.com/doc/guide/2.0/zh-cn/tutorial-performance-tuning 性能优化 有许多因素影响你的 Web 应用程序 ...
- Mysql性能优化之缓存参数优化
数据库属于 IO 密集型的应用程序,其主要职责就是数据的管理及存储工作.而我们知道,从内存中读取一个数据库的时间是微秒级别,而从一块普通硬盘上读取一个IO是在毫秒级别,二者相差3个数量级.所以,要优化 ...
- MySQL DBA教程:Mysql性能优化之缓存参数优化
在平时被问及最多的问题就是关于 MySQL 数据库性能优化方面的问题,所以最近打算写一个MySQL数据库性能优化方面的系列文章,希望对初中级 MySQL DBA 以及其他对 MySQL 性能优化感 ...
- IOS tableView的性能优化(缓存池)
使用缓存池(标识类型) 1.通过 一个 标识 去 缓存池 中寻找可循环得用的cell 2.如果缓存池找不到可循环得用的cell:创建一个新的cell(给cell贴个标识) 3.给cell设置新的数据 ...
- [js高手之路]性能优化技巧 - 缓存与函数重载实战
所谓缓存,通俗点讲就是把已经做过的事情结果先暂时存起来,下次再做同样的事情,不用再重新去做,只要把之前的存的结果拿出来用即可,很明显大大提升了效率.他的应用场景非常广泛.如: 1.缓存ajax结果,大 ...
- Django之缓存+序列化+信号+ORM性能优化+验证码
缓存 由于Django是动态网站,所有每次请求均会去数据进行相应的操作,当程序访问量大时,耗时必然会更加 明显,最简单解决方式是使用:缓存,缓存将一个某个views的返回值保存至内存或者memcach ...
- Yii2 性能优化 来源yii2官方文档
优化你的 PHP 环境 使用最新稳定版本的 PHP . PHP 的主要版本可能带来显著的性能提升. 启用字节码缓存 Opcache(PHP 5.5或更高版本) 或 APC (PHP 5.4或更早版本) ...
- Unity技术支持团队性能优化经验分享
https://mp.weixin.qq.com/s?__biz=MzU5MjQ1NTEwOA==&mid=2247490321&idx=1&sn=f9f34407ee5c5d ...
随机推荐
- win7无法通过DHCP获得IP地址
问题:win7无法通过DHCP获得IP地址(手动设置没有问题),但XP可以自动获取. 前些时候,某局域网反应部分WIN7系统无法正常从DHCP服务器(windows dhcp 服务器)获取ip地址,交 ...
- php curl语句的用法
system32文件夹下,修改php.ini文件,找到;extension= php_curl.dll行,去掉前面的;号,保存,重启服务器.在站点目录下建立一个PHP文件,内容如下 $ch = cur ...
- PHP最原始的上传文件函数
<?php $upload_file=$_FILES['upload_file']['tmp_name']; $upload_file_name=$_FILES['upload_file'][' ...
- run loop 输入源
做了一年多的IOS开发,对IOS和Objective-C深层次的了解还十分有限,大多还停留在会用API的级别,这是件挺可悲的事情.想学好一门语言还是需要深层次的了解它,这样才能在使用的时候得心应手,出 ...
- HDU 5787:K-wolf Number(数位DP)
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5787 题意:要求相邻的K个位的数不能相同,在[L,R]区间有多少个这样的数. #inclu ...
- Yahoo! s4和Twitter storm的粗略比较
- mysql 关联条件与查询(过滤)条件
mysql用outer join时 on 后边只是关联条件,有时可能会查出无用的记录, 需用where查询条件过滤 五欧诺个的数据. 记录一下
- idea项目无法自动导入maven库
解决:idea版本由15.0.*(需要Java8)降为14.1.4(Java7即可),搞定......
- 【转】MYSQL入门学习之九:索引的简单操作
转载地址:http://www.2cto.com/database/201212/176772.html 一.创建索引 www.2cto.com MYSQL常用的索引类型主要有以 ...
- [团队项目]----Math Calculator
团队项目 ----Math Calculator 任务: 1.每个团队从Github上fork这个项目的源代码 https://github.com/RABITBABY/We-have-bing 2. ...