Yii - Кеширование
Кэширование - это эффективный способ повысить производительность вашего приложения. Механизмы кеширования хранят статические данные в кеше и получают их из кеша по запросу. На стороне сервера вы можете использовать кеш для хранения основных данных, таких как список последних новостей. Вы также можете хранить фрагменты страниц или целые веб-страницы. На стороне клиента вы можете использовать кеширование HTTP, чтобы сохранить в кеше браузера страницы, которые вы посещали недавно.
Подготовка БД
Step 1- Создайте новую базу данных. База данных может быть подготовлена двумя способами.
В терминале запустите mysql -u root –p
.Создайте новую базу данных с помощью CREATE DATABASE helloworld CHARACTER SET utf8 COLLATE utf8_general_ci;
Step 2 - Настройте подключение к базе данных в config/db.phpфайл. Следующая конфигурация предназначена для системы, которая используется в настоящее время.
<?php
return [
'class' => 'yii\db\Connection',
'dsn' => 'mysql:host=localhost;dbname=helloworld',
'username' => 'vladimir',
'password' => '12345',
'charset' => 'utf8',
];
?>
Step 3 - Внутри корневой папки run ./yii migrate/create test_table. Эта команда создаст миграцию базы данных для управления нашей БД. Файл миграции должен появиться вmigrations папка корня проекта.
Step 4 - Измените файл миграции (m160106_163154_test_table.php в данном случае) так.
<?php
use yii\db\Schema;
use yii\db\Migration;
class m160106_163154_test_table extends Migration {
public function safeUp()\ {
$this->createTable("user", [ "id" => Schema::TYPE_PK, "name" => Schema::TYPE_STRING, "email" => Schema::TYPE_STRING, ]); $this->batchInsert("user", ["name", "email"], [
["User1", "[email protected]"],
["User2", "[email protected]"],
["User3", "[email protected]"],
["User4", "[email protected]"],
["User5", "[email protected]"],
["User6", "[email protected]"],
["User7", "[email protected]"],
["User8", "[email protected]"],
["User9", "[email protected]"],
["User10", "[email protected]"],
["User11", "[email protected]"],
]);
}
public function safeDown() {
$this->dropTable('user');
}
}
?>
Приведенная выше миграция создает userтаблица со следующими полями: идентификатор, имя и адрес электронной почты. Он также добавляет несколько демо-пользователей.
Step 5 - Внутри корня проекта run ./yii migrate применить миграцию к базе данных.
Step 6 - Теперь нам нужно создать модель для нашего userстол. Для простоты мы будем использоватьGiiинструмент генерации кода. Открой этоurl: http://localhost:8080/index.php?r=gii. Затем нажмите кнопку «Пуск» под заголовком «Генератор моделей». Введите имя таблицы («пользователь») и класс модели («MyUser»), нажмите кнопку «Предварительный просмотр» и, наконец, нажмите кнопку «Создать».
Модель MyUser должна появиться в каталоге моделей.
Кэширование данных
Кэширование данных помогает сохранять переменные PHP в кеше и извлекать их позже. Кэширование данных зависит от компонентов кеша, которые обычно регистрируются как компоненты приложения. Чтобы получить доступ к компоненту приложения, вы можете позвонитьYii::$app → cache. Вы можете зарегистрировать несколько компонентов приложения кеширования.
Yii поддерживает следующие кеш-хранилища -
yii \ caching \ DbCache - использует таблицу базы данных для хранения кэшированных данных. Вы должны создать таблицу, как указано в yii \ caching \ DbCache :: $ cacheTable.
yii \ caching \ ApcCache - использует расширение PHP APC.
yii \ caching \ FileCache - использует файлы для хранения кэшированных данных.
yii \ caching \ DummyCache - служит заполнителем кеша, который не выполняет реального кэширования. Цель этого компонента - упростить код, который должен проверять доступность кеша.
yii \ caching \ MemCache - использует расширение PHP memcache.
yii \ caching \ WinCache - использует расширение PHP WinCache.
yii \ redis \ Cache - реализует компонент кеширования на основе базы данных Redis.
yii \ caching \ XCache - использует расширение PHP XCache.
Все компоненты кеша поддерживают следующие API:
get () - извлекает значение данных из кеша с указанным ключом. Ложное значение будет возвращено, если значение данных истекло / недействительно или не найдено.
add () - сохраняет значение данных, идентифицированное ключом в кеше, если ключ не найден в кеше.
set () - сохраняет значение данных, идентифицированное ключом в кеше.
multiGet () - извлекает несколько значений данных из кеша с указанными ключами.
multiAdd () - сохраняет несколько значений данных в кеше. Каждый элемент обозначен ключом. Если ключ уже существует в кеше, значение данных будет пропущено.
multiSet () - сохраняет несколько значений данных в кеше. Каждый элемент обозначен ключом.
exists () - возвращает значение, указывающее, найден ли указанный ключ в кеше.
flush () - удаляет все значения данных из кеша.
delete () - удаляет значение данных, идентифицированное ключом, из кеша.
Значение данных, хранящееся в кэше, останется там навсегда, если оно не будет удалено. Чтобы изменить это поведение, вы можете установить параметр срока действия при вызове метода set () для хранения значения данных.
Значения кэшированных данных также могут быть признаны недействительными при изменении cache dependencies -
yii \ caching \ DbDependency - зависимость изменяется, если изменяется результат запроса указанного оператора SQL.
yii \ caching \ ChainedDependency - зависимость изменяется, если изменяется какая-либо из зависимостей в цепочке.
yii \ caching \ FileDependency - зависимость изменяется, если изменено время последней модификации файла.
yii \ caching \ ExpressionDependency - зависимость изменяется, если изменяется результат указанного выражения PHP.
Теперь добавьте cache компонент приложения к вашему приложению.
Step 1 - Измените config/web.php файл.
<?php
$params = require(__DIR__ . '/params.php');
$config = [ 'id' => 'basic', 'basePath' => dirname(__DIR__), 'bootstrap' => ['log'], 'components' => [ 'request' => [ // !!! insert a secret key in the following (if it is empty) - this //is required by cookie validation 'cookieValidationKey' => 'ymoaYrebZHa8gURuolioHGlK8fLXCKjO', ], 'cache' => [ 'class' => 'yii\caching\FileCache', ], 'user' => [ 'identityClass' => 'app\models\User', 'enableAutoLogin' => true, ], 'errorHandler' => [ 'errorAction' => 'site/error', ], 'mailer' => [ 'class' => 'yii\swiftmailer\Mailer', // send all mails to a file by default. You have to set // 'useFileTransport' to false and configure a transport // for the mailer to send real emails. 'useFileTransport' => true, ], 'log' => [ 'traceLevel' => YII_DEBUG ? 3 : 0, 'targets' => [ [ 'class' => 'yii\log\FileTarget', 'levels' => ['error', 'warning'], ], ], ], 'db' => require(__DIR__ . '/db.php'), ], 'modules' => [ 'hello' => [ 'class' => 'app\modules\hello\Hello', ], ], 'params' => $params,
];
if (YII_ENV_DEV) {
// configuration adjustments for 'dev' environment
$config['bootstrap'][] = 'debug'; $config['modules']['debug'] = [
'class' => 'yii\debug\Module',
];
$config['bootstrap'][] = 'gii'; $config['modules']['gii'] = [
'class' => 'yii\gii\Module',
];
}
return $config;
?>
Step 2 - Добавить новую функцию под названием actionTestCache() в SiteController.
public function actionTestCache() {
$cache = Yii::$app->cache; // try retrieving $data from cache
$data = $cache->get("my_cached_data");
if ($data === false) { // $data is not found in cache, calculate it from scratch
$data = date("d.m.Y H:i:s"); // store $data in cache so that it can be retrieved next time
$cache->set("my_cached_data", $data, 30);
}
// $data is available here var_dump($data);
}
Step 3 - Тип http://localhost:8080/index.php?r=site/test-cache в адресной строке веб-браузера вы увидите следующее.
Step 4- Если вы перезагрузите страницу, вы должны заметить, что дата не изменилась. Значение даты кэшируется, и срок действия кеша истекает в течение 30 секунд. Обновите страницу через 30 секунд.
Кеширование запросов
Кэширование запросов обеспечивает кеширование результатов запросов к базе данных. Для кэширования запросов требуется соединение с БД и компонент приложения кеширования.
Step 1 - Добавить новый метод под названием actionQueryCaching() в SiteController.
public function actionQueryCaching() {
$duration = 10; $result = MyUser::getDb()->cache(function ($db) { return MyUser::find()->count(); }, $duration);
var_dump($result); $user = new MyUser();
$user->name = "cached user name"; $user->email = "[email protected]";
$user->save();
echo "==========";
var_dump(MyUser::find()->count());
}
В приведенном выше коде мы кэшируем запрос к базе данных, добавляем нового пользователя и отображаем количество пользователей.
Step 2 - Перейти по URL http://localhost:8080/index.php?r=site/query-caching и перезагрузите страницу.
Когда мы открываем страницу впервые, мы кэшируем запрос к БД и отображаем количество всех пользователей. Когда мы перезагружаем страницу, результат кэшированного запроса БД будет таким же, как и был, потому что запрос к базе данных кэшируется.
Вы можете очистить кеш с консоли, используя следующие команды -
yii cache - Показывает доступные компоненты кеша.
yii cache/flush cache1 cache2 cache3 - Очищает компоненты кеша cache1, cache2 и cache3.
yii cache/flush-all - Очищает все компоненты кеша.
Step 3 - Внутри корня проекта вашего приложения запускается ./yii cache/flush-all.