Новости Joomla

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

👩‍💻 Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях. На старте его сайт на Joomla 3 вообще не смог обновиться на Joomla 5. Пришлось делать экспорт/импорт материалов. Проделав всё это он запустил-таки этот объём данных на Joomla 5. Тестовый скрипт грузил 200 материалов из этого объёма всего за 94 секунды ))) А главная страница с категориями грузилась 20 секунд. Добавив индекс для таблицы #__content

CREATE INDEX idx_catid_state ON #__content (catid, state);
он сократил время загрузки категорий до 1 секунды. Затем наш герой решил поковырять SQL-запрос в ArticleModel, который отвечает за выборку материалов. И решил заменить тип JOIN на STRAIGHT_JOIN для категорий.
// ->from($db->quoteName('#__content', 'a'))->from(    $db->quoteName('#__content', 'a')    . ' STRAIGHT_JOIN ' . $db->quoteName('#__categories', 'c')    . ' ON ' . $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))// ->join('LEFT', $db->quoteName('#__categories', 'c'), $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))
Что сократило загрузку 200 материалов из 150к с 94 секунд до 5. К слову сказать, боевой сайт на Joomla 3 крутится на 12CPU 64GB рамы. А все манипуляции с кодом он делает на базовом 1CPU 1GB сервере и замеры скорости даны именно для базового сервера. Но это всё в дискуссии, хотя в идеале должно вылиться в Pull Requests. Мы - Open Source сообщество, где никто никому ничего не должен. Джунгли. Но человек ищет пути оптимизации Joomla и предлагает решения. Если оказать поддержку и предложить помощь хотя бы с тестированием самых разнообразных сценариев, то возможно эти улучшения смогут войти в ядро. Пусть не быстро, пусть через несколько лет, пусть не все, но войдут. Достаточно предложить руку помощи и приложить немного усилий.
Дискуссию на GitHub можно почитать здесь.@joomlafeed#joomla #community #php

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

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Хочу из плагина передать в модель ContentModelArticles в функцию getListQuery() параметры для фильтрации контента на фронте. Конкретнее мне надо  передать подготовоенные иды и команду для применения их в запросе. Делал тремя способами:
Код: php
        $app = JFactory::getApplication();
        $app->setUserState('filter.article_id', 10);
        $app->setUserState('filter.article_id.include', true);

        $_POST['filter']['id'] = 10;
        $_POST['filter']['article_id'] = 10;

        JModelLegacy::addIncludePath(JPATH_SITE.'/components/com_content/models');
        $model = JModelLegacy::getInstance('Articles','ContentModel');
        $model->setState('filter.article_id', 10);
UserState как и ожидалось оказался нипричем, $_POST как не извращался не катит, JModelLegacy::getInstance каждый раз создает новый экземпляр этой модели, хотя в названии явно написано - инстанция. Я в тупике. Не знаю как передать модели нужные данные.
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Фильтрация контента в Joomla 3
« Ответ #1 : 11.02.2014, 12:47:03 »
Я правильно понял, что до момента, как отработает вывод контента на фронте (список материалов), плагин должен внести свои коррективы?
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: Фильтрация контента в Joomla 3
« Ответ #2 : 11.02.2014, 12:48:39 »
Конечно, onAfterInitialise(). Я проверяю $_POST в модели, он доходит, значит и все остальное доходит.
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Фильтрация контента в Joomla 3
« Ответ #3 : 11.02.2014, 12:56:17 »
Хмм... Дело в том, что метод getInstance() всегда возвращает новый экземпляр модели и название getInstance не должно означать, что должен возвращаться ранее созданный экземпляр. Вот как получить доступ к объекту модели, которая в данный момент выводит список, вот в чем вопрос. Сдается мне, что никак.
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
*

SmokerMan

  • Гуру
  • 5290
  • 720 / 26
Re: Фильтрация контента в Joomla 3
« Ответ #5 : 11.02.2014, 13:11:48 »
Хмм... Дело в том, что метод getInstance() всегда возвращает новый экземпляр модели и название getInstance не должно означать, что должен возвращаться ранее созданный экземпляр.
ну по идее getInstance подразумевает под собой синглтон) Т.е. дальше работа должна быть с созданным экземпляром, если он есть.

Кстати, на эту тему было интересное обсуждение:
Extend com_content with a new trigger onBeforeQueryContent
тоже, читал. Хорошая идея, но навряд ли ее внедрят.
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: Фильтрация контента в Joomla 3
« Ответ #6 : 11.02.2014, 13:16:20 »
То есть с фильтрацией контента полная труба?
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Фильтрация контента в Joomla 3
« Ответ #7 : 11.02.2014, 14:18:34 »
То есть с фильтрацией контента полная труба?
Получается, что так...

ну по идее getInstance подразумевает под собой синглтон) Т.е. дальше работа должна быть с созданным экземпляром, если он есть.
тоже, читал. Хорошая идея, но навряд ли ее внедрят.
Извиняюсь, ваша правда. Видимо в Joomla просто для совместимости оставили этот метод.
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: Фильтрация контента в Joomla 3
« Ответ #8 : 11.02.2014, 14:26:18 »
Конечно сильно жизнь они мне усложнили, придется что-нибудь с ком-серчем придумывать. Дай бог чтобы там таких-же граблей не схватить.
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Фильтрация контента в Joomla 3
« Ответ #9 : 11.02.2014, 14:32:03 »
Ну если почитать про Синглтон, то его считают злом в программировании. Его роль больше подходит для регистра. Поэтому Joomla отошла от этой практики и в этом вопросе я с разрабами согласен.
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: Фильтрация контента в Joomla 3
« Ответ #10 : 11.02.2014, 15:38:44 »
Про синглтон не спорю, но сделать такое деревянное расширение, что с ним ничего нельзя что не запрограммировано, это тоже неверно в корне. Такое пролоббировать могут только конкуренты com_content, типа разработчиков cck.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как и чем можно обращаться с запросами из Joomla к GraphQL?

Автор bmf1982

Ответов: 0
Просмотров: 947
Последний ответ 03.10.2019, 15:46:00
от bmf1982
Joomla как система авторизации

Автор kav

Ответов: 23
Просмотров: 2807
Последний ответ 29.04.2018, 11:10:30
от Aleks.Denezh
Нужна помощь в доработке модуля под Joomla 3

Автор kik84

Ответов: 5
Просмотров: 2795
Последний ответ 30.01.2018, 22:40:30
от Елeна
Как отучить Joomla стартовать session для гостей?

Автор commeta

Ответов: 8
Просмотров: 3495
Последний ответ 20.08.2015, 14:06:38
от acyp
Значение из контента перенести в модуль

Автор leo78

Ответов: 42
Просмотров: 3357
Последний ответ 31.07.2015, 19:51:00
от leo78