Новости 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 Гость просматривают эту тему.
  • 6 Ответов
  • 6748 Просмотров

Доброе время суток.
Никак не пойму как сделать.
Как получить в компоненте значение переменной из модуля?
Написал модуль навигации по видеокатегориям, который отображает список категорий и количество позиций, найденных в данной категории. Как мне передать эти параметры (выбранную категорию и кол-во элементов в ней) в самописанный компонент, который уже подробно показывает найденное в этой категории? Не хочу делать второй запрос из компонента, чтобы не повышать зазря нагрузку на базу данных, ведь компонент "уже в курсе".
« Последнее редактирование: 03.03.2006, 04:30:14 от kamud »

я не совсем понял, что нужно, но можно двумя путями (в зависимости от того что нужно):
1) передать методом Get в ссылке]
2) в модуле и компоненте при определении переменной использовать не $blabla a $GLOBALS['blabla']

первый вариант не подходит, потому что сначала при построении навигации выполняется модуль, который жирным выделяет в навигации нужную строку, соответствующую текущей категории, а потом когда дело доходит до выполнения компонента на этой же странице (в этой же загрузке страницы пользователем), то компоненту нужно видеть что там нагенерировал модуль.
Скорее всего подойдёт второй вариант. Сейчас попробую. Заранее спасибо.

С $GLOBALS не получается. Не передаётся параметр. :(

А ты ГЛОБАЛЗ и в модуле и вкомпоненте используеш? Попробуй переименовать эту глобальную переменную (не blabla a blablo, например) - вдруг она совпадает с уже где то имеющейся переменной?
Попробуй проверить передачу перемнной путем echo, print() или print_r() - может она передается, только ты ее обрабатываеш не так?
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
первый вариант не подходит, потому что сначала при построении навигации выполняется модуль
что-то ты не так говоришь :) в Joomla сначала инициализируется компонент, и оторабатывает параметры которые ему передали в запросе, а затем уже подгружается шаблон, и в него модули. поэтому если модуль будет формировать правильные ссылки с нужными параметрами, то компонент сможет нормально на них реагировать.

Тогда не понимаю.
То есть вне зависимости от очерёдности модулей и компонентов в их настройках в админке. Всегда сначала выполняется модуль, а затем шаблон и модули, которые в этом шаблоне упоминаются?
Стало быть джумла выполняет сначала тот компонент, который указан в параметре option, а потом уже всю обвязку?

....Действительно так. Если я задаю глобальный параметр в компоненте, то в модуле я его вижу.

Спасибо.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вставка кода вызова модуля в тело шаблона другого модуля

Автор Dorfman

Ответов: 15
Просмотров: 2646
Последний ответ 19.11.2018, 21:45:54
от beliyadm
Как создать дополнительный параметр(по типу published) для элемента списка?

Автор borro

Ответов: 4
Просмотров: 1630
Последний ответ 08.02.2018, 17:03:11
от borro
Нужна помощь в доработке модуля под Joomla 3

Автор kik84

Ответов: 5
Просмотров: 2794
Последний ответ 30.01.2018, 22:40:30
от Елeна
params->get для компонента, как получить свои собственные параметры для компонента

Автор klubnichkaaa

Ответов: 13
Просмотров: 14362
Последний ответ 01.06.2017, 20:20:28
от Septdir
По ID'у пункта меню получить ссылку для перехода

Автор GRIG

Ответов: 4
Просмотров: 3126
Последний ответ 08.05.2017, 17:13:05
от Aleks.Denezh