Кеширование
Подключение
'components'=>array( ... // Отключаем кеш 'cache'=>array('class'=>'system.caching.CDummyCache'), // Кеширование //'cache'=>array('class'=>'system.caching.CFileCache'), //'cache'=>array('class'=>'system.caching.CApcCache'), //'cache'=>array('class'=>'system.caching.CMemCache', 'servers'=>array(array('host'=>'localhost', 'port'=>'11211', 'weight'=>'100') ... ),
Настройки
Использование
База
DAO
$sql = 'SELECT * FROM tbl_post LIMIT 20'; // кешируем результат запроса 1000 секунд $rows = Yii::app()->db->cache(1000)->createCommand($sql)->queryAll();
Если данные в таблице меняются, можно попробовать инвалидировать кеш, используя менее затратный запрос:
$sql = 'SELECT * FROM tbl_post LIMIT 20'; // сбрасываем кеш, если результат изменился $dependency = new CDbCacheDependency('SELECT MAX(update_time) FROM tbl_post'); // кешируем на 1000 секунд $rows = Yii::app()->db->cache(1000, $dependency)->createCommand($sql)->queryAll();
AR
$posts = Post::model()->cache(1000)->findAll(); $posts = Post::model()->cache(1000)->with('author')->findAll();
Представления
<?php if($this->beginCache($id)) { ?> ---Фрагмент страницы который хотим закэшировать--- <?php $this->endCache(); } ?>
if($this->beginCache('emem_catalog', array('duration'=>60*60*24*365,'dependency'=>array( 'class'=>'system.caching.dependencies.CDirectoryCacheDependency', 'directory'=>$dir_to_check)))) { $this->widget('apposWidgetAppCatalog',array( 'model'=>$this->model, )); $this->endCache();