<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Chapter 14. Кэширование</title>
<meta name="generator" content="DocBook XSL Stylesheets V1.75.1">
<link rel="home" href="index.html" title="Руководство по Smarty">
<link rel="up" href="smarty.for.programmers.html" title="Part III. Smarty для программистов">
<link rel="prev" href="api.unregister.resource.html" title="unregister_resource">
<link rel="next" href="caching.multiple.caches.html" title="Множественное кэширование страниц">
</head>
<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
<div class="navheader">
<table width="100%" summary="Navigation header">
<tr><th colspan="3" align="center">Chapter 14. Кэширование</th></tr>
<tr>
<td width="20%" align="left">
<a accesskey="p" href="api.unregister.resource.html">Prev</a> </td>
<th width="60%" align="center">Part III. Smarty для программистов</th>
<td width="20%" align="right"> <a accesskey="n" href="caching.multiple.caches.html">Next</a>
</td>
</tr>
</table>
<hr>
</div>
<div class="chapter" title="Chapter 14. Кэширование">
<div class="titlepage"><div><div><h2 class="title">
<a name="caching"></a>Chapter 14. Кэширование</h2></div></div></div>
<div class="toc">
<p><b>Table of Contents</b></p>
<dl>
<dt><span class="sect1"><a href="caching.html#caching.setting.up">Настройка кэширования</a></span></dt>
<dt><span class="sect1"><a href="caching.multiple.caches.html">Множественное кэширование страниц</a></span></dt>
<dt><span class="sect1"><a href="caching.groups.html">Групповое кэширование</a></span></dt>
<dt><span class="sect1"><a href="caching.cacheable.html">Управление кэшированием результатов работы плагинов</a></span></dt>
</dl>
</div>
<p>
Кэширование используется для ускорения вызовов <a class="link" href="api.display.html" title="display()">display()</a> или <a class="link" href="api.fetch.html" title="fetch">fetch()</a> при помощи сохранения результатов
их работы в файл. Если доступна кэшированная версия вызова, она отображается
вместо повторной обработки шаблона. Кэширование может значительно ускорить
работу, особенно в случае длительно обрабатываемых шаблонов.
Так как результат работы методов <a class="link" href="api.display.html" title="display()">display()</a> или <a class="link" href="api.fetch.html" title="fetch">fetch()</a> кэшируется, один файл кэша вполне может
состоять из нескольких файлов шаблонов, конфигурационных файлов и т.д.
</p>
<p>
Так как шаблоны динамичны, очень важно быть осторожным относительно того,
что вы кэшируете и на какой период. Например, если вы отображаете главную
страницу вашего сайта, которая меняет своё содержимое достаточно редко,
хорошей идеей может быть кэширование этой страницы на час и более.
С другой стороны, если вы отображаете страницу с картой погоды, которая
обновляется ежеминутно, смысла в кэшировании этой страницы нет.
</p>
<div class="sect1" title="Настройка кэширования">
<div class="titlepage"><div><div><h2 class="title" style="clear: both">
<a name="caching.setting.up"></a>Настройка кэширования</h2></div></div></div>
<p>
Прежде всего, кэширование необходимо активировать. Это можно сделать,
установив <a class="link" href="variable.caching.html" title="$caching">$caching</a> = true (или 1).
</p>
<div class="example">
<a name="id2732142"></a><p class="title"><b>Example 14.1. Включение кэширования</b></p>
<div class="example-contents"><pre class="programlisting">
require('Smarty.class.php');
$smarty = new Smarty;
$smarty->caching = true;
$smarty->display('index.tpl');
</pre></div>
</div>
<br class="example-break"><p>
При включенном кэшировании, вызываемая функция display('index.tpl') интерпретирует
шаблон как обычно, но также сохраняет копию вывода в файл (кэшированую копию)
в <a class="link" href="variable.cache.dir.html" title="$cache_dir">$cache_dir</a>.
При следующем вызове display('index.tpl'), вместо повторной интерпретации шаблона,
будет использована кешированая копия.
</p>
<div class="note" title="Техническое замечание" style="margin-left: 0.5in; margin-right: 0.5in;">
<h3 class="title">Техническое замечание</h3>
<p>
Файлы в директории $cache_dir имеют те же имена, что и соответствующие
шаблоны. Их имена оканчиваются расширением ".php", но на самом деле они не являются
выполняемыми php-скриптами. Не редактируйте эти файлы!
</p>
</div>
<p>
Каждая кэшированая страничка существует на протяжении определенного времени,
указанного в <a class="link" href="variable.cache.lifetime.html" title="$cache_lifetime">$cache_lifetime</a>.
Значение по умолчанию равно 3600 секундам или 1 часу. После того, как это время
истекает, кэш обновляется. Существует возможность присвоить каждой
кэшированой страничке собственное время жизни, установив $caching = 2.
Смотрите документацию <a class="link" href="variable.cache.lifetime.html" title="$cache_lifetime">$cache_lifetime</a>
для получения подробных сведений.
</p>
<div class="example">
<a name="id2732858"></a><p class="title"><b>Example 14.2. Установка собственного cache_lifetime для кэшированой копии</b></p>
<div class="example-contents"><pre class="programlisting">
require('Smarty.class.php');
$smarty = new Smarty;
$smarty->caching = 2; // Срок действия только для этой копии
// устанавливаем cache_lifetime для index.tpl в 5 минут
$smarty->cache_lifetime = 300;
$smarty->display('index.tpl');
// устанавливаем cache_lifetime для home.tpl в 1 час
$smarty->cache_lifetime = 3600;
$smarty->display('home.tpl');
// Примечание: следующая $cache_lifetime настройка не будет работать, когда $caching = 2.
// Срок жизни кэша для home.tpl уже был установлен
// в 1 час, и Smarty больше не будет обращать внимание на значение $cache_lifetime.
// Время жизни кэша home.tpl по прежнему будет истекать по прошествию одного часа.
$smarty->cache_lifetime = 30; // 30 секунд
$smarty->display('home.tpl');
</pre></div>
</div>
<br class="example-break"><p>
Если включен параметр <a class="link" href="variable.compile.check.html" title="$compile_check">$compile_check</a>,
то каждый файл шаблона и конфигурации, связанный с файлом кэша, проверяется на
наличие изменений. Если один из этих файлов был модифицирован с тех пор, как
кэш был создан, кэш немедленно обновляется. Это незначительно повышает нагрузку,
поэтому, для оптимальной производительности оставьте значение $compile_check
равным false.
</p>
<div class="example">
<a name="id2732894"></a><p class="title"><b>Example 14.3. Включение $compile_check</b></p>
<div class="example-contents"><pre class="programlisting">
require('Smarty.class.php');
$smarty = new Smarty;
$smarty->caching = true;
$smarty->compile_check = true;
$smarty->display('index.tpl');
</pre></div>
</div>
<br class="example-break"><p>
Если <a class="link" href="variable.force.compile.html" title="$force_compile">$force_compile</a>
активирован, файлы кэша всегда будут обновляться. Это средство можно
использовать для отключения кэширования во время отладки.
$force_compile обычно используется только в целях отладки, так как более
правильным способом отключения кеширования является установка
<a class="link" href="variable.caching.html" title="$caching">$caching</a> = false (или 0).
</p>
<p>
Функция <a class="link" href="api.is.cached.html" title="is_cached">is_cached()</a> может быть
использована для определения, имеется ли у шаблона работоспособный кэш.
Если у вас есть кэшированый шаблон, которому необходимо, например,
получить выборку из базы данных, вы можете использовать эту функцию,
чтобы пропустить процесс обращения к базе.
</p>
<div class="example">
<a name="id2732995"></a><p class="title"><b>Example 14.4. Использование is_cached()</b></p>
<div class="example-contents"><pre class="programlisting">
require('Smarty.class.php');
$smarty = new Smarty;
$smarty->caching = true;
if(!$smarty->is_cached('index.tpl')) {
// Кэш отсутствует, значит присваеваем значения переменным.
$contents = get_database_contents();
$smarty->assign($contents);
}
$smarty->display('index.tpl');
</pre></div>
</div>
<br class="example-break"><p>
Вы можете сделать так, чтобы часть страницы оставалась динамической, даже
если страница кэшируется, при помощи встроенной функции <a class="link" href="language.function.insert.html" title="{insert}">insert</a>. Например,
кэшироваться может вся страница, за исключением баннера.
Используя функцию insert для баннера, вы можете сохранять
этот элемент динамичным, внутри кэшированой странички. Смотрите
документацию по <a class="link" href="language.function.insert.html" title="{insert}">insert</a> для
получения подробностей и примеров.
</p>
<p>
Очистить все файлы кэша можно при помощи функции
<a class="link" href="api.clear.all.cache.html" title="clear_all_cache()">clear_all_cache()</a>, а
конкретный файл кэша (или группу) - вызвав
<a class="link" href="api.clear.cache.html" title="clear_cache()">clear_cache()</a> функцию.
</p>
<div class="example">
<a name="id2733082"></a><p class="title"><b>Example 14.5. Очистка кэша</b></p>
<div class="example-contents"><pre class="programlisting">
require('Smarty.class.php');
$smarty = new Smarty;
$smarty->caching = true;
// очищаем все файлы кэша
$smarty->clear_all_cache();
// очищаем только кэш шаблона index.tpl
$smarty->clear_cache('index.tpl');
$smarty->display('index.tpl');
</pre></div>
</div>
<br class="example-break">
</div>
</div>
<div class="navfooter">
<hr>
<table width="100%" summary="Navigation footer">
<tr>
<td width="40%" align="left">
<a accesskey="p" href="api.unregister.resource.html">Prev</a> </td>
<td width="20%" align="center"><a accesskey="u" href="smarty.for.programmers.html">Up</a></td>
<td width="40%" align="right"> <a accesskey="n" href="caching.multiple.caches.html">Next</a>
</td>
</tr>
<tr>
<td width="40%" align="left" valign="top">unregister_resource </td>
<td width="20%" align="center"><a accesskey="h" href="index.html">Home</a></td>
<td width="40%" align="right" valign="top"> Множественное кэширование страниц</td>
</tr>
</table>
</div>
</body>
</html>