Yii2 redis与cache

原文地址:http://www.myexception.cn/php/1974979.html

composer require yiisoft/yii2-redis

安装后使用超简单,打开 common/config/main.php 文件,修改如下。

‘cache‘ => [
    // ‘class‘ => ‘yii\caching\FileCache‘,
    ‘class‘ => ‘yii\redis\Cache‘,
],
‘redis‘ => [
    ‘class‘ => ‘yii\redis\Connection‘,
    ‘hostname‘ => ‘localhost‘,
    ‘port‘ => 6379,
    ‘database‘ => 0,
],

OK,现在已经用 redis 接管了yii的缓存,缓存的使用和以前一样,以前怎么用现在还是怎么用,但是有个不算bug的bug,所以算小坑,等会会说。

来测试下 cache 先,

Yii::$app->cache->set(‘test‘, ‘hehe..‘);
echo Yii::$app->cache->get(‘test‘), "\n";

Yii::$app->cache->set(‘test1‘, ‘haha..‘, 5);
echo ‘1 ‘, Yii::$app->cache->get(‘test1‘), "\n";
sleep(6);
echo ‘2 ‘, Yii::$app->cache->get(‘test1‘), "\n";

来看下测试结果。

和原来一样的用法,没问题。。

但是刚才我说过了有个不算bug的bug,所以算小坑,到底是什么东西呢?
如果你直接用 redis 接管了 cache,如果正常使用是完全没问题的,但是当 过期时间 的值超过 int 范围的时候,redis就会报错。
我使用了 yii2-admin,凑巧让我踩到坑了,因为他缓存了30天,也就是2592000秒,并且 redis 缓存时间精度默认用毫秒,所以时间就是 2592000000 毫秒。
而 redis 的过期时间只能是int类型,Cache.php 里的 php 强制转为int,而没有做其他处理,所以就会变成 -1702967296 然后就报错了。

但是直接在 redis 命令行下不会负数,如图。

不过没关系,修复起来也很简单,我们修改为秒即可。
打开 vendor/yiisoft/yii2-redis/Cache.php 第 133 行,修改为如下代码。

protected function setValue($key, $value, $expire)
{
    if ($expire == 0) {
        return (bool) $this->redis->executeCommand(‘SET‘, [$key, $value]);
    } else {
        // $expire = (int) ($expire * 1000); // 单位默认为毫秒
        // return (bool) $this->redis->executeCommand(‘SET‘, [$key, $value, ‘PX‘, $expire]);

        $expire = +$expire > 0 ? $expire : 0; // 防止负数
        return (bool) $this->redis->executeCommand(‘SET‘, [$key, $value, ‘EX‘, $expire]); // 按秒缓存
    }
}

这样就OK了。

时间: 2024-10-17 19:13:50

Yii2 redis与cache的相关文章

yii2 redis使用

$redis = Yii::$app->redis;$keys = 'dll_mb_examine';//定义键名$list = $redis->get($keys);//取key值if(empty($list)){    $data=Examine::getMobileExamine($userInfo['userId']);    if(empty($data)){        return $this->redirect(['/frontend/default/nomsg','m

redis实现cache系统实践(六)

1. 介绍 rails中就自带有cache功能,不过它默认是用文件来存储数据的.我们要改为使用redis来存储.而且我们也需要把sessions也存放到redis中.关于rails实现cache功能的源码可见于这几处: https://github.com/rails/rails/blob/master/activesupport/lib/active_support/cache.rb https://github.com/rails/rails/tree/master/activesuppor

redis作为cache和session的数据库的使用

package main import ( _ "./routers" "fmt" "github.com/astaxie/beego" _ "github.com/astaxie/beego/cache/redis" "github.com/astaxie/beego/cache" "log" "time" ) type hashes struct { name s

Yii2 redis 使用

首先要安装一下redis的扩展 composer require yiisoft/yii2-redis 在配置文件中添加redis配置 'components' => [ .... 'redis' => [ 'class' => 'yii\redis\Connection', 'hostname' => yourname, 'password' => yourPassword, 'port' =>6379,//默认的端口 配置其他端口在这里改 'database' =&

Redis+Django(Session,Cookie、Cache)的用户系统

转自 http://www.cnblogs.com/BeginMan/p/3890761.html 一.Django authentication django authentication 提供了一个便利的user api接口,无论在py中 request.user,参见 Request and response objects .还是模板中的 {{user}} 都能随时随地使用,如果从web开发角度来看,其实无非就是cookie与session的运用. 在项目首页,在登陆和注销状态下分别输出

Spring Boot (24) 使用Spring Cache集成Redis

Spring 3.1引入了基于注解(annotation)的缓存(cache)技术,它本质不是一个具体的缓存实现方案,而是一个对缓存使用的抽象,通过在既有代码中添加少量它定义的个助攻annotation,就能够达到缓存方法的返回对象的效果. 特点 具备相当好的灵活性,不仅能够使用SpEL来定义缓存的key和各种condition,还提供开箱即用的缓存临时存储方案,也支持和主流的专业缓存例如EHCache.Redis.Guava的集成. 基于annotation即可使得现有代码支持缓存 开箱即用O

Spring Boot(八)集成Spring Cache 和 Redis

在Spring Boot中添加spring-boot-starter-data-redis依赖: <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> 在application.properties中指定redis服务器IP.端口和密码.

Spring整合Redis做数据缓存(Windows环境)

当我们一个项目的数据量很大的时候,就需要做一些缓存机制来减轻数据库的压力,提升应用程序的性能,对于java项目来说,最常用的缓存组件有Redis.Ehcache和Memcached. Ehcache是用java开发的缓存组件,和java结合良好,直接在jvm虚拟机中运行,不需要额外安装什么东西,效率也很高:但是由于和java结合的太紧密了,导致缓存共享麻烦,分布式集群应用不方便,所以比较适合单个部署的应用. Redis需要额外单独安装,是通过socket访问到缓存服务,效率比Ehcache低,但

spring redis 整合

<import resource="cache/applicationContext-redis.xml"/> applicationContext-redis.xml <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation