zoukankan      html  css  js  c++  java
  • ThinkPHP中的动态缓存(S方法)和快速缓存(F方法)

    系统默认的缓存方式是采用File方式缓存,我们可以在项目配置文件里面定义其他的缓存方式,例如,修改默认的缓存方式为Xcache(当然,你的环境需要支持Xcache)

        对于File方式缓存下的缓存目录下面因为缓存数据过多而导致存在大量的文件问题,ThinkPHP也给出了解决方案,可以启用哈希子目录缓存的方式。

        'DATA_CACHE_SUBDIR'=>true   

        还可以设置哈希目录的层次,例如

        'DATA_PATH_LEVEL'=>2  

        就可以根据缓存标识的哈希自动创建多层子目录来缓存。

        S方法支持缓存有效期,在很多情况下,可能我们并不需要有效期的概念,或者使用文件方式的缓存就能够满足要求,所以系统还提供了一个专门用于文件方式的快速缓存方法F方法。F方法只能用于缓存简单数据类型,不支持有效期和缓存对象,使用如下:
       
        //快速缓存Data数据,默认保存在DATA_PATH目录下面    
          F('data',$data);
        //快速缓存Data数据,保存到指定的目录   
          F('data',$data,TEMP_PATH);
          F('user/data',$data);
        //删除缓存数据
          F('data',null);
        //获取缓存数据
          $data=F('data');        

    配置文件config.php

    //动态缓存,缓存文件存在于RuntimeTemp
    'DATA_CACHE_TYPE'=>'file',
    'DATA_CACHE_TIME'=>'3600',
    //'DATA_CACHE_SUBDIR'=>true,//开启子目录
    //'DATA_CACHE_LEVEL'=>3,//设置子目录的层次

    Action文件:

        function view(){
            //缓存
            //$cache=Cache::getInstance('缓存方式','缓存参数');
            //$cache=Cache::getInstance('Xcache',array('expire'=>60));
            //$cache->set('名字','值');或者$cache->name='值';
            //$value=$cache->get('名字');或者$value=$cache->name;
            //$cache->rm('名字');或者unset($cache->name);
           
            //S('名字','数据','3600','类型')缓存快捷方法
             
            $user=M('haodetong');
           
            $value=S('list');
            if(empty($value)){
                $list=$user->select();
               
                S('list',$list,3600);
                echo '这个是直接从数据库中读取的文件';   
                dump($list);
            }else{
                echo '这个是缓存文件';
                dump($value);
            }
          
        }

    第一次访问时如下图:

    ThinkPHP中的动态缓存(S方法)和快速缓存(F方法)

    再次刷新后如下图:

    ThinkPHP中的动态缓存(S方法)和快速缓存(F方法)

  • 相关阅读:
    python中的基础坑
    Django组件content-type使用方法详解
    数据库范式
    MySQL常见面试题索引、表设计
    python操作MySQL之pymysql模块
    MySQL备份与还原
    MySQL查询缓存
    MySQL索引及查询优化
    MySQL事务隔离之MVCC版本控制
    MySQL事务及实现、隔离级别及锁与优化
  • 原文地址:https://www.cnblogs.com/echohao/p/4910308.html
Copyright © 2011-2022 走看看