0 Пользователей и 1 Гость просматривают эту тему.
  • 4 Ответов
  • 4259 Просмотров
*

yunoshev

  • Завсегдатай
  • 1271
  • 179 / 1
Многие жалуются на скорость загрузки страниц категории K2 при использовании плагина дополнительных категорий (чтоб одну статью можно было указать для разных категорий).
Решение по оптимизации весьма простое: добавить индексы полей catid, itemID в таблицу _k2_additional_categories.

Т.е. в БД должно быть вот так:
Спойлер
[свернуть]

Что у нас тормозило:
Спойлер
[свернуть]

Что в итоге получаем:
Спойлер
[свернуть]

И еще один запрос, который берет количество записей от предыдущего запроса, можно оптимизировать следующим путем.
Открываем файл components\com_k2\models\itemlist.php, ищем функцию getTotal() и меняем на:
Код: php
	function getTotal()
{
$user = JFactory::getUser();
$aid = $user->get('aid');
$db = JFactory::getDBO();
$params = K2HelperUtilities::getParams('com_k2');
$task = JRequest::getCmd('task');

// An elegant way to calculate rows
$db->setQuery('SELECT FOUND_ROWS()');  // no reloading the query! Just asking for total without limit
return $db->loadResult();
}
Спойлер
[свернуть]

В общем, у моего заказчика все работает теперь и быстро грузится ( http://krasnogorsk.telemo.ru/catalog/uslugi/dostavka-tsvetov ).
*

voland

  • Легенда
  • 11031
  • 588 / 112
  • Эта строка съедает место на вашем мониторе
Картинок нет..
Я, впрочем уже оптимизировал и только потом натолкнулся на этот коммент.

Кратко - добавляем индекс в #_k2_additional_categories для полей itemID и catid

Насчет второй части - не понял, там же куча условий фильтрации порушится, так? То есть применимо только для малой части сайтов.

Ну и для поисковиков
K2, Additional Categories, k2_additional_categories, тормоза, медленно работает, ускорение, index, хак, улучшение, ускорение
*

tomat_ok

  • Осваиваюсь на форуме
  • 44
  • 1 / 0
Вторая часть это уже индивидуальная доработка была, она не обязательна. Тут главное индексы добавить и будет сильно быстрей работать.
*

voland

  • Легенда
  • 11031
  • 588 / 112
  • Эта строка съедает место на вашем мониторе
ЗЫ.
yunoshev, а как нашелся источник тормозов?
Или было понятно сразу в чём он?

А то я включал дебаг, делал в нём измерения скорости..
Но, я так понял, что эти запросы не попадают в дебаг
*

yunoshev

  • Завсегдатай
  • 1271
  • 179 / 1
@voland
Тоже через Debug, просмотр запросов, что тормозят сайт (там ведь их время выполнения пишется), и анализ кода, оптимизация запросов.
Функция с getTotal() используется практически один раз и по назначению, поэтому ее изменение не приведет к нарушению работы компонента.
А в первом случае - да, тормоза были с индексами. Я на форуме разработчиков написал об этом детально еще в те дни и они пообещали исправить данный недочет в новой версии. Но исправили или нет -- не могу знать уже :)

Удачи!
« Последнее редактирование: 25.11.2015, 22:39:26 от yunoshev »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Не открываются файлы после загрузки на сайт

Автор GeniusUd

Ответов: 1
Просмотров: 539
Последний ответ 01.02.2021, 17:19:38
от voland
Ищу модуль для вывода категорий k2 с функцией AJAX загрузки

Автор Slava77

Ответов: 1
Просмотров: 976
Последний ответ 10.08.2017, 10:25:34
от Septdir
[Решено] Оптимизация загрузки изображения в статью k2

Автор cmotp10

Ответов: 10
Просмотров: 5634
Последний ответ 31.07.2016, 20:10:16
от Septdir
СЕО-оптимизация сайта на K2

Автор AlucarD

Ответов: 5
Просмотров: 2130
Последний ответ 19.03.2015, 08:42:32
от ChaosHead
Канонические ссылки в связке J3 + K2

Автор Light_And_Dark

Ответов: 0
Просмотров: 1220
Последний ответ 17.02.2015, 18:48:00
от Light_And_Dark