zoukankan      html  css  js  c++  java
  • Cache缓存机制与文件缓存原理PHP

    PHP Cache缓存机制与文件缓存原理,使用 PEAR 中的 cache 可以将内容缓存于文件,数据库或者内存中,以文件为例。

    没有使用缓存

    pear_content_cache1.php

    <?php 
        echo "这是内容。<P>"; 
        echo "当前时间是" . date('M-d-Y H:i:s A', time()) . "<BR>"; 
    ?>
    

      

    为其加上缓存

    pear_content_cache2.php

    <?php 
        require_once 'Cache/Output.php';
        //设置缓存目录,必须是可写的 
        $cacheDir = './pear_cache'; 
        $cache = new Cache_Output('file',array('cache_dir' => $cacheDir));
        //如果nocache变量为空,使用缓存中的内容 
        //如果想获得最新的内容,就要赋值给nocache变量 
       if (empty($_REQUEST['nocache'])) 
     { 
      // 建立一个独一的cache标识 
      // 请求+Cookie信息 
      $cache_id = $cache->generateID(array('url' => $_REQUEST,'post' =>$_POST,'cookies' => $HTTP_COOKIE_VARS)); 
     } 
     else 
     { 
       //想获得最新的内容,ID为空 
       $cache_id = null; 
     }
     //看cache ID对应的缓存内容是否可用 
     if ($content = $cache->start($cache_id)) 
     { 
      //缓存已存在,直接输出,并结束脚本 
      echo $content; 
      exit(); 
     }
     // 缓存中不存在该内容,生成新内容并写入缓存 
     echo "这是内容。<P>"; 
     echo "当前时间是" . date('M-d-Y H:i:s A', time()) . "<BR>";
     // 把内容写入缓存 
     echo $cache->end(); 
    ?>
    

      

    分别刷新这两个文件,你会发现 pear_content_cache1.php 中的“当前时间是”这一行中的时间是随着刷新而变化的,而 pear_content_cache2.php 中的这一行则不变。

    这是由于 pear_content_cache2.php 使用了缓存,将用户请求的内容存入静态文件中。当用户再次请求时,它直接从文件中输出,而不需要用程序动态生成内容。

    对于 pear_content_cache2.php ,如果用户想要读取最新的信息,而不是缓存中成旧的信息。那么可以用http.//… /pear_content_cache2.php?nocache=1 来访问,这将禁用缓存功能,刷新一下看看,你将发现时间会随之变化。

    总结PEAR内容缓存类的使用:

    1、包含 PEAR 包 要注意路径。

    2、包含Output.php中的cache类

    require_once 'Cache/Output.php';
    

    3、设置缓存目录

    $cacheDir = './pear_cache'; 

    确认这个目录是可写的,Cache数据将会写入这个目录的子目录中。

    4、建立一个输出缓存对象

    $cache = new Cache_Output('file',array('cache_dir' => $cacheDir));

    第一个参数表示我们使用基于“文件”方式的缓存,第二个参数是一个与缓存目录相关联的数组。

    5、产生一个唯一的cache ID

    $cache_id = $cache->generateID(array('url' => $_REQUEST,'post' =>$_POST,'cookies' => $HTTP_COOKIE_VARS));

    这里 $cache 对象的 generateID() 方法通过提供一个信息数组 (URL, HTTP POST data, 和 HTTP cookie) 来独一无二地标识这个请求,与其它请求区分开来。

    6、增加一个逻辑判断语句看是否对应于cacheID的缓存数据是否已经存在,如果存在,获取数据并结束脚本。

    if ($content = $cache->start($cache_id)) 
    { 
        echo $content; 
        exit(); 
    }
    

    7、将产生内容的代码放在以上逻辑语句之后,并结束使用cache对象。

    echo $cache->end();
    

      

    函数缓存输出 PEAR cache

    PEAR除了可以对输出的内容进行缓存处理外,还可以将对某个函数的调用结果缓存起来。这是个很有趣的功能,如果你的程序要频繁使用到某个函数,而且调用的结果相同的话,我建议你不妨试试,特别是当这个函数运行起来比较慢的时候。

          下面我们实现对一个执行起来很慢的函数 slowFunction() 的缓冲调用。

    <?php 
     require_once 'Cache/Function.php'; 
     $cacheDir = './pear_cache/'; 
     $cache = new Cache_Function('file',array('cache_dir' => $cacheDir)); 
     $arr = array('东方', '南方','西方'); 
     $cache->call('slowFunction', $arr); 
     echo '<BR>'; 
     $arr = array('东方', '南方','西方');
      slowFunction($arr);
     function slowFunction($arr = null) 
     { 
      echo "执行起来很慢的函数 :( <br>"; 
      echo "当前时间是 " . date('M-d-Y H:i:s A', time()) . '<br>'; 
      foreach ($arr as $fruit) 
      { 
       echo "太阳此时正在 $fruit <br>"; 
      } 
     ) 
    ?>
    

      

  • 相关阅读:
    Scrapy框架基础使用
    python爬虫练习--爬取今日头条街拍图片
    python爬虫练习--爬取所有微博
    python爬虫练习--爬取猫眼热映口碑榜
    python练习---校园管理系统
    python爬虫练习--爬取猫眼top100电影信息
    基础篇-Python的urllib库
    1--爬虫环境安装篇
    Confluence 如何查看页面 ID
    导入 Gradle 项目到 IntelliJ IDEA
  • 原文地址:https://www.cnblogs.com/fyy-888/p/5070398.html
Copyright © 2011-2022 走看看