caching.html 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=0" />
  6. <title>缓存适配器 - CodeIgniter 中文手册|用户手册|用户指南|Wiki文档</title>
  7. <link rel="shortcut icon" href="http://codeigniter.org.cn/user_guide/../images/design/favicon.ico" type="image/x-icon" />
  8. <link rel="stylesheet" type="text/css" media="all" href="../userguide.css" />
  9. <link rel="search" href="http://codeigniter.org.cn/user_guide/../CodeIgniterSearch.xml" type="application/opensearchdescription+xml" title="CodeIgniter 搜索"/>
  10. <link rel="canonical" href="http://codeigniter.org.cn/user_guide/drivers/caching.html" />
  11. <script type="text/javascript" src="../nav/mootools.js-ver=20130324.js"></script>
  12. <script type="text/javascript" src="../nav/mootools-more.js-ver=20130324.js"></script>
  13. <script type="text/javascript" src="../nav/nav.js-ver=20130324.js"></script>
  14. <script type="text/javascript" src="../nav/user_guide_menu.js-ver=20130324.js"></script>
  15. <meta name="robots" content="all" />
  16. <meta name="author" content="ExpressionEngine Dev Team" />
  17. <meta name="description" content="CodeIgniter 中文手册, CodeIgniter 用户指南, CodeIgniter User Guide, Wiki 文档" />
  18. </head>
  19. <body>
  20. <!-- START NAVIGATION -->
  21. <div id="nav">
  22. <div id="nav_inner">
  23. <script type="text/javascript">create_menu('../');</script>
  24. </div>
  25. </div>
  26. <script type="text/javascript">_setNavigation();</script>
  27. <div id="nav2"><a name="top"></a><a href="javascript:void(0);" onclick="myHeight.toggle();"><img src="../images/nav_toggle_darker.jpg" width="154" height="43" border="0" title="切换目录" alt="切换目录" /></a></div>
  28. <div id="masthead" class="clearfix">
  29. <div class="topbar-hd"><h1>CodeIgniter 用户指南 版本 2.2.0</h1></div>
  30. <div class="topbar-tip">编辑文档、查看近期更改请 <a href="#">登录</a> 或 <a href="#">注册</a>  <a href="#">找回密码</a></div> <div id="breadcrumb_right"><a href="../toc.html">目录页</a></div>
  31. </div>
  32. <!-- END NAVIGATION -->
  33. <!-- START BREADCRUMB -->
  34. <table cellpadding="0" cellspacing="0" border="0" style="width:100%">
  35. <tr>
  36. <td id="breadcrumb">
  37. <a href="#" target="_blank">CodeIgniter 中国首页</a>&nbsp;&#8250;&nbsp;
  38. <a href="../index.html">用户指南首页</a>&nbsp;&#8250;&nbsp;<a href="../index.html">适配器</a>&nbsp;&#8250;&nbsp;缓存适配器 </td>
  39. <td id="searchbox">
  40. <form method="get" action="http://www.google.com.hk/search" target="google_window">
  41. <input type="hidden" name="client" value="pub-0176846097796333"></input>
  42. <input type="hidden" name="forid" value="1"></input>
  43. <input type="hidden" name="ie" value="UTF-8"></input>
  44. <input type="hidden" name="oe" value="UTF-8"></input>
  45. <input type="hidden" name="as_sitesearch" id="as_sitesearch" value="codeigniter.org.cn/user_guide/" />
  46. 搜索用户指南&nbsp;
  47. <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" />
  48. &nbsp;
  49. <input type="submit" class="submit" name="sa" value="Go" />
  50. </form>
  51. </td>
  52. </tr>
  53. </table>
  54. <!-- END BREADCRUMB -->
  55. <div style="clear:both;text-align:right;padding: 6px 40px 0 0;">
  56. <a href="#" target="_blank">查看原文</a>
  57. </div>
  58. <!--<br clear="all" />--><!-- START CONTENT -->
  59. <div id="content">
  60. <h1>缓存适配器</h1>
  61. <p>注:在2.0.3以前有bug,请下载最新版本的CI。</p>
  62. <p>CodeIgniter提供了多种目前业界流行的快速动态缓存组件的封装类。除了基于纯文本的缓存(文件缓存)外,其他缓存组件均需对服务器环境进行正确配置才能使用,否则程序会抛出致命异常(Fatal Exception)错误。</p>
  63. <p></p>
  64. <h2>目录</h2>
  65. <ul>
  66. <li><a href="#example_usage" title="Example Usage">用法举例</a></li>
  67. <li><a href="#function_reference" title="Function Reference">函数速查</a></li>
  68. </ul>
  69. <h3>支持的缓存适配器</h3>
  70. <ul>
  71. <li><a href="#apc" title="APC Cache">Alternative PHP Cache (APC) 缓存</a></li>
  72. <li><a href="#file" title="File Caching">纯文本缓存</a></li>
  73. <li><a href="#memcached" title="Memcached">Memcached缓存</a></li>
  74. <li><a href="#dummy" title="Dummy Caching">虚拟缓存</a></li>
  75. </ul>
  76. <h2 id="example_usage">用法举例</h2>
  77. <p>下面这个例子:首先加载缓存适配器,然后指定 <a href="#apc" title="APC">APC</a> 作为适配器优先使用的缓存实现,同时,我们指定文本缓存作为替代方案。这样,在一些服务器不支持APC的情况下(如国内的虚拟主机),我们可以使用替代方案保证程序正常运行。</p>
  78. <code>
  79. $this-&gt;load-&gt;driver('cache', array('adapter' => 'apc', 'backup' => 'file'));<br />
  80. <br />
  81. if ( ! $foo = $this-&gt;cache-&gt;get('foo'))<br />
  82. &#123;<br />
  83. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;echo 'Saving to the cache!&lt;br />';<br />
  84. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$foo = 'foobarbaz!';<br />
  85. <br />
  86. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;// Save into the cache for 5 minutes<br />
  87. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this-&gt;cache-&gt;save('foo', $foo, 300);<br />
  88. &#125;<br />
  89. <br />
  90. echo $foo;
  91. </code>
  92. <p><strong>译者注:为了便于理解上面的代码,我们不妨举个例子。缓存适配器,我们可以理解为一个“通电的插座”;而APC缓存,相当于我们希望插在插座上使用的空调;文本缓存我们可以理解与空调功能相同但效率却完全不同的电风扇。</strong></p>
  93. <h1 id="function_reference">Function Reference</h1>
  94. <h2>is_supported(<var>driver</var>['string'])</h2>
  95. <p>如果你通过 <samp>$this-&gt;cache-&gt;get()</samp> 来访问缓存适配器,此函数将自动触发。但是,如果你希望有针对性的使用某个具体的缓存实现(如下例中的 APC),请确保调用此函数,用来检查服务器环境是否支持这种缓存类型。</p>
  96. <code>
  97. if ($this-&gt;cache-&gt;apc-&gt;is_supported())<br />
  98. &#123;<br />
  99. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if ($data = $this-&gt;cache-&gt;apc-&gt;get('my_cache'))<br />
  100. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#123;<br />
  101. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;// do things.<br />
  102. &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#125;<br />
  103. &#125;
  104. </code>
  105. <h2>get(<var>id</var>['string'])</h2>
  106. <p>此函数将尝试从缓存系统中获取指定的缓存项。如果缓存不存在,或者超过缓存期限,则返回 <samp>FALSE</samp>。</p>
  107. <code>$foo = $this-&gt;cache-&gt;get('my_cached_item');</code>
  108. <h2>save(<var>id</var>['string'], <var>data</var>['mixed'], <var>ttl</var>['int'])</h2>
  109. <p>此函数尝试将一个缓存项存储到对应的缓存系统中。如果存储失败,则返回<samp>FALSE</samp>。</p>
  110. <p>第三个参数(可选项)指定了缓存的存活时间,默认为60秒。</p>
  111. <code>$this-&gt;cache-&gt;save('cache_item_id', 'data_to_cache');</code>
  112. <h2>delete(<var>id</var>['string'])</h2>
  113. <p>此函数尝试从缓存系统中删除某个指定的缓存项。如果删除失败,则返回<samp>FALSE</samp>。</p>
  114. <code>$this-&gt;cache-&gt;delete('cache_item_id');</code>
  115. <h2>clean()</h2>
  116. <p>此函数用来清空所有缓存。如果清空失败,则返回 <samp>FALSE</samp>.</p>
  117. <code>$this-&gt;cache-&gt;clean();</code>
  118. <h2>cache_info()</h2>
  119. <p>此函数将返回所有缓存信息.</p>
  120. <code>var_dump($this-&gt;cache-&gt;cache_info());</code>
  121. <h2>get_metadata(<var>id</var>['string'])</h2>
  122. <p>此函数将返回缓存系统中指定缓存项的详细信息。</p>
  123. <code>var_dump($this-&gt;cache-&gt;get_metadata('my_cached_item'));</code>
  124. <h1>Drivers</h1>
  125. <h2 id="apc">Alternative PHP Cache (APC) 缓存</h2>
  126. <p>以上列举的所有方法可直接访问,不需传递特定的适配器实现给适配器加载器,如下:</p>
  127. <code>$this-&gt;load-&gt;driver('cache');<br />
  128. $this-&gt;cache-&gt;apc-&gt;save('foo', 'bar', 10);</code>
  129. <p>For more information on APC, please see <a href="#">http://php.net/apc</a></p>
  130. <h2 id="file">基于文件的缓存</h2>
  131. <p>不同于从输出类(Output Class)缓存, 基于文件的缓存可以对view页面分块缓存。不过使用时需要小心,应该通过对程序进行评测,以确保由于磁盘I/O增加所导致的性能下降相对于缓存所带来的性能提升是值得的。</p>
  132. <p>以上列举的所有方法可直接访问,不需传递特定的适配器实现给适配器加载器,如下:</p>
  133. <code>$this-&gt;load-&gt;driver('cache');<br />
  134. $this-&gt;cache-&gt;file-&gt;save('foo', 'bar', 10);</code>
  135. <h2 id="memcached">Memcached 缓存</h2>
  136. <p>使用分布式 Memcached 服务器 可以通过配置文件: memcached.php 来配置,该文件在 <samp>application/config/</samp> 目录下.
  137. <p>以上列举的所有方法可直接访问,不需传递特定的适配器实现给适配器加载器,如下:</p>
  138. <code>$this-&gt;load-&gt;driver('cache');<br />
  139. $this-&gt;cache-&gt;memcached-&gt;save('foo', 'bar', 10);</code>
  140. <p>若想了解更多关于 Memcached的信息, 请参考 <a href="#">http://php.net/memcached</a></p>
  141. <h2 id="dummy">虚拟缓存(Dummy Cache)</h2>
  142. <p>虚拟缓存是一种总是被忽略的后台缓存。它不存储数据,但是若有的环境不支持你选择的缓存机制时,它可以让你的缓存代码能正常的执行。</p><p>&nbsp;</p>
  143. <div id="Contributors">
  144. 翻译贡献者:
  145. amos, cnsaturn, Hex, LSvKing, qixingyue, tangjianft, wdlth, zxuqian, 曜日晨阳</div>
  146. <div id="DocDate">
  147. 最后修改: 2013-03-19 02:37:26</div>
  148. </div>
  149. <!-- END CONTENT -->
  150. <div id="footer">
  151. <p>
  152. 上一个主题:&nbsp;&nbsp;<a href="../libraries/zip.html">Zip 编码类</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  153. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="../database/index.html">数据库类库</a> </p>
  154. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  155. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  156. </div>
  157. </body>
  158. </html>