Форум русской поддержки Joomla!® CMS
02.12.2016, 22:07:02 *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

Войти
   
   Начало   Поиск Joomla 3.0 FAQ Joomla 2.5 FAQ Joomla 1.5 FAQ Правила форума Новости Joomla Реклама Войти Регистрация Помощь  
Страниц: [1]   Вниз
  Добавить закладку  |  Печать  
Автор

Оптимизация загрузки K2 в связке с плагином k2additonalcategories

 (Прочитано 462 раз)
0 Пользователей и 1 Гость смотрят эту тему.
yunoshev
Разработчик расширений для Joomla 1.0
*

Репутация: +176/-1
Offline Offline

Пол: Мужской
Сообщений: 1234


« : 06.08.2015, 02:34:24 »

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

Т.е. в БД должно быть вот так:
Показать текстовый блок

Что у нас тормозило:
Показать текстовый блок

Что в итоге получаем:
Показать текстовый блок

И еще один запрос, который берет количество записей от предыдущего запроса, можно оптимизировать следующим путем.
Открываем файл components\com_k2\models\itemlist.php, ищем функцию getTotal() и меняем на:
Код
	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
Профи
********

Репутация: +487/-85
Online Online

Пол: Мужской
Сообщений: 8694


любит наш народ всякое гавно...


« Ответ #1 : 25.11.2015, 20:22:58 »

Картинок нет..
Я, впрочем уже оптимизировал и только потом натолкнулся на этот коммент.

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

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

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

Репутация: +1/-0
Offline Offline

Пол: Мужской
Сообщений: 44



« Ответ #2 : 25.11.2015, 20:25:39 »

Вторая часть это уже индивидуальная доработка была, она не обязательна. Тут главное индексы добавить и будет сильно быстрей работать.
Записан
voland
Профи
********

Репутация: +487/-85
Online Online

Пол: Мужской
Сообщений: 8694


любит наш народ всякое гавно...


« Ответ #3 : 25.11.2015, 20:35:00 »

ЗЫ.
yunoshev, а как нашелся источник тормозов?
Или было понятно сразу в чём он?

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

Репутация: +176/-1
Offline Offline

Пол: Мужской
Сообщений: 1234


« Ответ #4 : 25.11.2015, 23:36:01 »

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

Удачи!
« Последнее редактирование: 25.11.2015, 23:39:26 от yunoshev » Записан
Страниц: [1]   Вверх
  Добавить закладку  |  Печать  
 
Перейти в:  

Powered by SMF 1.1.21 | SMF © 2006, Simple Machines

Joomlaforum.ru is not affiliated with or endorsed by the Joomla! Project or Open Source Matters.
The Joomla! name and logo is used under a limited license granted by Open Source Matters
the trademark holder in the United States and other countries.

LiveInternet