Кэширование в MODX: использование $modx->cacheManager

MODX использует менеджер кэширования для хранения и извлечения данных из кэша. $modx->cacheManager - это экземпляр класса modCacheManager, который предоставляет методы для работы с кэшем.

Основные методы MODX Cache

Сохранить в кэш — set($key, $var, $lifetime = 0, $options = [])

Этот метод используется для сохранения данных ($value) в кэше с определенным ключом ($key) и временем жизни ($lifetime, в секундах).

Важно отметить, что параметр $options может быть использован для указания конкретных опций кэширования, таких как раздел кэша (cache partition).

  $options = array(
    'cache_key' => 'my_custom_partition',
  );
  $modx->cacheManager->set('my_key', 'my_value', 3600);

Получить из кэша — get($key, $options = [])

Этот метод используется для получения данных из кэша по определенному ключу ($key). Если данных с указанным ключом нет, метод вернет NULL.

$value = $modx->cacheManager->get('my_key', $options);

Удалить из кэша — delete ($key, $options = [])

Этот метод используется для удаления данных из кэша по определенному ключу ($key)

$modx->cacheManager->delete('my_key', $options);

Обновить кэш — refresh($options = [])

Этот метод используется для обновления системного кэша.

$modx->cacheManager->refresh([
    'context_settings' => ['contexts' => ['web', 'web2'] ]
]);

Очистить кэш — clean($options = [])

Этот метод очищает все или выбранные типы кэша, основанные на параметрах, переданных в $options.

$modx->cacheManager->clean($options);

Для чего нужно указывать $options

Параметр $options используется для передачи дополнительных настроек и опций при работе с кэшем. Он позволяет вам гибко настраивать поведение кэширования в зависимости от потребностей. Вот некоторые распространенные примеры использования $options:

  1. Разделы кэша (cache partitions):
    Вы можете создать разделы кэша, чтобы группировать связанные данные вместе и изолировать их от других данных. Это упрощает управление кэшем и позволяет очищать определенные группы данных, не затрагивая остальные. Параметр 'cache_key', или стандарная переменная, хранящая эту же строку xPDO::OPT_CACHE_KEY, определяет название папки, в которой будет хранится кэш. Эту папку можно найти в дирректории core/cache/{'cache_key'} Чтобы указать раздел кэша, добавьте 'cache_key' в $options:
$options = array(
    'cache_key' => 'my_custom_partition',
);
$modx->cacheManager->set('my_key', 'my_value', 3600, $options);
  1. Пользовательские обработчики кэша:
    MODX позволяет использовать собственные обработчики кэша для хранения данных в других системах кэширования, таких как Memcached, Redis и т.д. Вы можете указать пользовательский обработчик, добавив 'handler' и 'handlerOptions' в $options:
$options = array(
    'handler' => 'myCustomCacheHandler',
    'handlerOptions' => array(
        'option1' => 'value1',
        'option2' => 'value2',
    ),
);
$modx->cacheManager->set('my_key', 'my_value', 3600, $options);
  1. Компоненты MODX:
    Если вы разрабатываете компонент для MODX, может потребоваться использовать собственный раздел кэша или обработчик кэша для хранения данных вашего компонента. В этом случае вы также можете использовать параметр $options для передачи настроек кэширования.

Обратите внимание, что в зависимости от выбранного метода кэширования и класса кэширования, могут быть доступны различные опции. Проверьте документацию по вашему обработчику кэша, чтобы узнать о всех доступных опциях.

Комментарии (0)

  1. Напишите первый комментарий
*Комментарий будет опубликован после проверки модератором

Похожие статьи

Генератор настроек MIGX

Документация на русском по MODX MIGX

Подсказки по работе и заготовки для MiniShop2

pdoPage и getImageList - Постраничная навигация MIGX

Импорт и экспорт в MiniShop2. Реализация 1

Как включить HTTPS (SSL) в MODX - Подробная инструкция

Генерация YML для выгрузки в маркет

Примеры работы с API MODX

Примеры выборки where, optionFilters, innerJoin

pThumb - ресайз изображений. Примеры использования.

Расширение свойств товаров minishop2

Примеры использования

Сайт на обслуживании (выключить сайт)

Добавить в письмо контактную информацию

Вывести getImageList только если он не пустой

Тип поля "Список ресурсов" (resourcelist) с ограничением по родителю (parents)

Оформление и настройка easyComm. Комментарии и отзывы на сайте.

Поиск на сайте с пакетом SimpleSearch

Простая и симпатичная галерея fancybox

Подсчет и вывод количества потомков ресурса в MODX

Галерея. Вывести обложки альбомов и фотографии

Вывод tv-параметров в формате -

Отредактировать письмо о заказе - добавить ТВ поле, или что-то еще

Quip для MODX. Более рабочий вариант

pdoResources Заготовки для работы

Сниппет для вывода размера и расширения файла

Простой аудио-плеер HTML5

Вывести список всех опций MiniShop2

Слайдер Slick slider в контенте ресурса

Как контролировать кэш CSS и скриптов

Изменить цену на товар в зависимости от количества при добавлении в корзину minishop2

Подключить MODX в стороннем PHP файле

Простейшая авторизация

Как создать ресурс процессором $modx->runProcessor('resource/create', $props)

Красивое адаптивное меню под pdoMenu

Массово обновить ТВ, или другое поле через базу

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

Изменить формат номера заказа

Сообщение о том, что сайт использует Cookie

Получить grandparent. Вывести родитель родителя

Симпатичный список файлов, загружаемых к ресурсу через MIGX

Установить шаблон по-умолчанию для новых, создаваемых ресурсов

Создать источник файлов

Вывести все доступные плейсхолдеры

Отредактировать шаблон письма

Добавить скрипт перед тегом body

Общая сумма по каждому товару в корзине Minishop2

Создать раздел с паролем на сайте MODX

Что делать если ее приходит почта администратору

Фильтрация по TV параметрам в msProducts

Дата на русском

FontAwesome - часто используемые иконки для шаблонов MODX

Создать пакет с пользовательской таблицей

Заготовки для работы

Курсы валют с cbr.ru на PHP

Загрузка сниппета после загрузки страницы через AjaxSnippet

getResources заготовки

Обязательный чекбокс при оформлении заказа

Обработка остатков заказа в miniShop2

Соответствие названия классов с названиями таблиц в MySQL

Разбить вывод pdoResources на несколько колонок (блоков)

Баннеры с использованием BannerY

Обновить alias (псевдоним) у всех ресурсов

CSS для постраничной навигации pdoPage

Вывести время загрузки (формирования) страницы

Расширить таблицу site_content (объект modResource) за 5 минут

Вырезать кавычки — фильтр-сниппет MODX

Счетчик посещений и скачиваний для сортировки ресурсов

Бесплатная доставка от 5000 рублей в MiniShop2

Динамическое поле emailSubject в FormIt

Скрыть информацию о том, что сайт работает на MODX

Отсортировать ресурсы по количеству комментариев Quip MODx

Изменить цену на товар, если в корзине лежит товар из особой категории minishop2

Создать редирект через autoRedirector API

Ответ для сервиса moneta.ru

Вывести 404 ошибку по настройке TV MODX

Cортировать по списку id в pdoResources и pdoTools

Email сделать не обязательным полем

Как разместить исходный код сниппета на сайте, в документации

Ускорить установку MODX revo до пары кликов

Постраничная навигация — набор параметров и CSS PdoPage

Сделать все элементы статичными для Git и IDE

Не работает подгрузка товаров ajax mfilter2 на мобильном

Сделать поле размер обязательным

Подключить текстовой редактор к доп. полям ресурса

Настройка стилей для комментариев Tickets

Кастомный чанк для AdminPanel

Динамическая замена шаблона ресурса - плагин

Разместить корзину внутри блока с оформлением заказа

Плагин для формирования замороженных URL с редиректом

xPDO Выборка из одной таблицы с зацепкой значения из другой

Приветственный экран / заглушка на сайт

Вложенные условия в xPDO MODX

Вывести список всех родителей в ТВ поле ресурса

Как получить данные пользователя сразу после авторизации через API

Вывести список всех емэйлов miniShop2

Если getParentIds не работает в плагине

Контролировать кэширование файлов CSS и JS MiniShop2

Не приходят / не отправляются письма - в чем причина?

Кэширование в MODX: использование $modx->cacheManager

Наш сайт использует куки, нажмите «ОК» если вы не против
OK