测试框架版本说明

  • 测试yii2版本

    77103@DESKTOP-C2JB47R MINGW64 /e/dev/basic
    $ ./yii
    
    This is Yii version 2.0.15.1.
    
    The following commands are available:

    配置文件

  • 配置memcache,在web.php / main.php 中配置

    'components' => [
          //数据缓存到memcache
          'cache' => [
              'class' => 'yiicachingMemCache',
              'servers' => [
                  [
                      'host' => 'localhost',
                      'port' => 11211,
                      'weight' => 100,
                  ]
              ],
          ],

    代码1

    <?php
    
    namespace app\controllers;
    
    use yii\web\Controller;
    use Yii;
    
    class TestController extends Controller
    {
    
      public function actionIndex()
      {
          $key = 'people';
          $value = json_encode(array('name'=>'ball', 'age'=>'male'));
          $expire = 60000;
          yii::$app->cache->set($key, $value,$expire);
          $data =Yii::$app->cache->get($key);
          \Logic::vd($data);
      }
    }
    // 结果:bool(false) 

    代码2

    <?php
    
    namespace app\controllers;
    
    use yii\web\Controller;
    use Yii;
    
    class TestController extends Controller
    {
    
      public function actionIndex()
      {
          $key = 'people';
          $value = json_encode(array('name'=>'ball', 'age'=>'male'));
          $expire = 60000;
          yii::$app->cache->set($key, $value);
          $data =Yii::$app->cache->get($key);
          \Logic::vd($data);
      }
    }
    //结果:string(28) "{"name":"ball","age":"male"}"

    解决

  • 在yii2使用memcache前根据文档配置好相应的参数,在使用memcache(非memcached)过程中会发现Yii::$app->cache->set('key','value');,当这句话没有设置有效时间为多少秒时,可以正常获取到缓存中键为key的值,但表示此key不过期。
  • 当设置了有效时间时,Yii::$app->cache->set('key','value',60);比如60秒,就会出现取不到key对应的value值,网上和论坛里搜了搜,没有找到解决办法,也有很多phper遇到这类似的问题。所以特意去看了看底层代码,引用的memcache类为Yii2自带的yii\caching\MemCache,Yii::$app->cache->set('key','value');这句代码会自动调用memcache类下的setValue方法来设置缓存,所以问题也许就出现在这儿了。
  • 后面经过测试,发现这个方法最后一句 。 return $this->useMemcached ? $this->_cache->set($key, $value, $expire) : $this->_cache->set($key, $value, 0, $expire)的问题,将这句代码改为return $this->useMemcached ? $this->_cache->set($key, $value, $expire) : $this->_cache->set($key, $value, 0, $duration)后, 再测试发现问题已经解决。
  • 原因则是这句return代码里使用memcache时调用的$this->_cache->set($key, $value, 0, $expire), 相当于$mem = new Memcache();$mem->set($key,$value,0,$expire); 这里最关键的一点是:memcache要设置的时间的含义是有效时间为多少秒, memcached要设置的时间的含义是在哪一秒到期(等效于time()+$duration), 所以发现问题所在之后将原来代码里的第二个$expire改成$duration问题就解决啦,因为发现是个系统bug, 所以在论坛里来告诉大家一下,再有小伙伴遇到这个问题直接改一下这里就好, 还有如果哪位小伙伴有精神可以告诉下yii2开发团队, 下次yii升级的时候就可以修复这个bug了,暂时没修复时小伙伴们就照我上面说的改一下就可以用了。
Last modification:February 25, 2022
如果觉得我的文章对你有用,请随意赞赏