Печать

Секреты кэширования в Joomla 1.5

Обычно в вебе, один и то же контент отображается снова и снова. Кэширование позволяет увеличить скорость генерации, сохраняя уже сгенерированную страницу в файл. Есть разные способы сделать это, но я рассмотрю только один из методов. Хочу обрадовать, что в joomla кэширование реализуется очень просто:)

Используем JProfiler

При использовании функции кэширования вам наверняка будет интересно узнать насколько ускорился ваш скрипт. Для этого мы будем использовать класс joomla JProfiler.

<?php
// Создаем объект JProfiler.
$profiler = new JProfiler();
 
// Отображаем время.
echo $profiler->mark( ' секунд прошло' );
 
?>

Создаем тестовую функцию

Мы сделаем небольшой компонент, который фактически ничего не делает, но на его примере, я покажу как рассчитать время, необходимое для выполнения функции. Во-первых нужно создать файл компонента:
/components/com_testcache/testcache.php
В файле создадим класс с одним методом:

 
<?php 
// нет прямого допуска.
defined( '_JEXEC' ) or die( 'Restricted access' );
 
class TestClass {
 
    function testMethod() {
 
        // подключаемся к бд.
        $db = & JFactory::getDBO();
 
        // выполняем 250 запросов в бд.
        for ($i=0; $i<250; $i++) {
            $db->setQuery( 'SELECT * FROM #__content' );
            $rows = $db->loadObjectList();
        }
 
        return $rows;
    }
}
 
// запускаем наш метод.
$rows = TestClass::testMethod();
 
?>
 

250 запросов - это много. Но так мы заметим разницу в производительности с кэшированием и без него.

Объект кэширования

Для начала включите кэширование в глобальных настройках cms joomla.
Теперь создадим ссылку на класс кэширования через JFactory

<?php
$cache = & JFactory::getCache();
?>

Если вы хотите, чтобы ваш компонент использовал кэширование, даже если оно отключено в глобальной конфигурации, Вы можете настроить его сами:

<?php
$cache->setCaching( 1 );
?>
 

Далее вызовим наш метод через объект кэширования:

<?php
$rows = $cache->call( array( 'TestClass', 'testMethod' ) );
?>
 

Если мы хотим вызвать кэширование конкретной функции, то не нужно использовать массив:

<?php
$rows  = $cache->call( 'testFunction' );
?>
 

Во время тестирования кода, мы можем использовать следующий метод для очистки кэша:

<?php
$cache->cleanCache();
?>
 

Этот метод удалит все файлы из папки /cache

Теперь объеденим все вместе

Чтобы сравнить производительность, вызываем наш метод два раза. Один разу через объект кэша, и один раз без него:

<?php
class TestClass {
 
    function testMethod() {
 
        $db = & JFactory::getDBO();
 
        for( $i=0; $i<250; $i++) {
            $db->setQuery( 'SELECT * FROM #__content' );
            $rows = $db->loadObjectList();
        }
 
        return $rows;
    }
}
 
// создаем объект кэша
$cache = & JFactory::getCache();
 
// тестируем без кэша
$profiler = new JProfiler();
$rows = TestClass::testMethod();
echo $profiler->mark( ' без кэша' );
 
// тестируем с кэшем
$profiler = new JProfiler();
$rows  = $cache->call( array( 'TestClass', 'testMethod' ) );
echo $profiler->mark( ' с кэшем' );
?>

Теперь запускаем наш компонент через index.php?option=com_testcache. Первые результаты будут такими:

2.093 без кэша
2.160 с кэшем

Результат с кэшированием получился больше, потому что некоторое время ушло на запись кэша в файл. Теперь перезагрузим страницу в броузере.

2.073 без кэша
0.008 с кэшем
 Нехилые результаты?:) а теперь умножьте выигранное время на колличество посетителей, и поймете свой реальный выигрыш;)

Кеширования HTML вывода в Joomla 

Joomla позволяет кешировать отдельные части шаблонов, компонентов, а именно их вывод. Для этого необходимо создать объект кеша с обработчиком "output", так как показано


Создается кеш-объект c обработчиком "output". "com_test" в данном случае - это место хранения кеша: /cache/com_test ( в случае файлового кеша)

Далее выбирается идентификатор кеширования. Он должен зависеть например от внешних условий расширения. Таким образом для разных страниц, с разными Itemid будет создаваться разный кеш и не будет путаницы. В принципе можно подставлять сериализованые массивы с текущими параметрами вызова и прочее. Хорошим вариантом можно считать следующий вариант:

$Itemid = JRequest::getvar('Itemid', 1);
$id = JRequest::getvar('id');
$cache_id = $Itemid .'_'. $id .'_'. $lastModifiedId;

Таким образом обновление произойдет автоматический сброс при изменении элемента администратором сайта.

Внимание: Будте осторожны с выбором идентификатора кеша. Например использование следующих вариантов грозит резким ростом размера кеша, особенно на больших сайтах с высокой посещаемостью. Эффективность кеширования пойдет к нулю, более того в какой-то мере это можно считать дырой в безопасности сайта.

$cache_id = serialize($_GET);
$cache_id = serialize($_REQUEST);

Далее начинаем непосредственный перехват вывода. Если файл кеша отсутствует или истек период его жизни, то функция start() вернет "false", в противном случае функция вернет "true".

В случае просроченного/отсутсвующего кеша - запуститься буферизация вывода. Заканчивается буферизация после выполнения end(). Если start() вернул "true", будет использован тот текст, который хранился с прошлого раза в файлах кеша. 

Интересная статья? Поделись ей с другими: