Во время работы над одним из сайтов мною было обнаружено, что меню навигации K2 по категориям (ещё в версии 2.4, так и в версии 2.5) осуществляет по 3 запроса на получение одной категории.
Итого: меню из 300 категорий обернулось 1100 запросами к базе данных.
Да. Есть кэш. И в К2 он замечательно организован. Но что делать, если: кэш включать нельзя, и что делать с автоматизированными пользователями, для которых кэш к2 работает странно (порой вообще не работает).

Сокращаем количество запросов на треть:
Убираем счётчик материалов в навигации категорий K2.
Заходим в панель администрирования – в верхнем меню расширения - менеджер модулей – ищем модуль mod_k2_tools, отвечающий за вывод навигации по категориям, щелкаем по его названию (в параметрах модуля в выпадающем списке «Выберите функциональность модуля» должно быть отмечено «Категории (меню)»), переходим в правой части экрана к «Категории (меню) Настройки», отмечаем флаг «Счётчик материалов» – «скрыть», в верхнем правом углу экрана нажимаем «Сохранить».
Но всё равно количество запросов остаётся неприемлемым. Слишком «расточительным».
Я переписал файл /modules/mod_k2_tools/helper.php
Теперь меню навигации по категориям делает всего один запрос (с отключенным счётчиком материалов напротив категории) для формирования всего дерева категорий без потери или изменения функциональности (а не по три на каждую категорию).
Почему с глобальным? Для дальнейших модификаций (а в К2 есть ещё что оптимизировать), в которых k2 так же использует идентичные запросы к категориям.
Идея такова: один раз запрашиваем все категории, дальше работаем с глобальным массивом (модификация касается пока что только меню навигации по категориям, но так же применима и к выпадающему списку категорий)
В итоге количество потребляемой памяти возросло для 300 категорий на 1 мб, а количество всех запросов на главной странице упало с 1100 до 16.
Модифицированный helper.php для навигаций Вы можете скачать по
ссылке или в аттаче к посту.
С подробным описанием модификации Вы можете ознакомиться
здесьТестировалось с Joomla 1.5.25, K2 2.5.3,2.5.4.
Просьба отписаться о работе на Joomla 1.7.
[вложение удалено Администратором]