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

master-smeta

  • Захожу иногда
  • 298
  • 10 / 0
Здравствуйте. Возникла проблема с выводом модулей через ModuleHelper. Модули вытаскиваю так:
Код
$modules_bottom = ModuleHelper::getModules('content-bottom');
foreach($modules_bottom as $module_b):
echo ModuleHelper::renderModule($module_b);
endforeach;
К позиции "content-bottom" привязано много разных модулей, но все они привязаны к разным страницам. В целом, обычная привязка модулей к страницам, просто модульная позиция прописана не в шаблоне, а в макете.
Проблема в том, что с недавнего времени в модульную позицию выводятся все опубликованные модули, независимо от привязки к страницам.
Т.е. была страница "1" и на нее выводился модуль "А". На страницу "2" выводился модуль "Б". В какой-то момент на страницах "1" и "2" выводятся модули и "А" и "Б".
Предположительно проблема пошла после обновления до Joomla 5.0.2, т.к. на локалке стоит 5.0.1 и там всё работает нормально.
В патчноуте к 5.0.2 упоминаний про модули не нашел, в Google вроде тоже тихо.
Может кто-нибудь подскажет вариант решения проблемы?
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
Re: Moduleer::getModules фильтрация модулей
« Ответ #1 : 14.02.2024, 19:36:19 »
Попробуйте выводить позицию модулей другими способами

1.
Код
echo Factory::getDocument()->loadRenderer('modules')->render('content-bottom', array('style' => 'raw'), null);

2.
Код
echo Html::_('content.prepare', '{loadposition content-bottom}');

Не забудьте про use для Document и для HTML.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

master-smeta

  • Захожу иногда
  • 298
  • 10 / 0
Re: Moduleer::getModules фильтрация модулей
« Ответ #2 : 15.02.2024, 09:40:21 »
Ерунда какая-то. Сегодня обновил страницу и все модули отображаются нормально  *ОХ-Х-Х* ничего не менял, вообще ничего! Сам работаю в техподдержке и всем клиентам на фразу типа "вчера работало, ничего не делала, сегодня не работает" отвечаю: "само ничего не происходит...". Но тут, я ничего не делал! Оно само сломалось и само потом починилось!  *suicide*
Можно было бы предположить, что это звоночек, может быть кто-то что-то на хостинге меняет или взлом какой-нибудь... Но в защите я уверен + настроены всякие уведомляшки об изменении файлов. А что такого можно поменять на хостинге, чтобы перестала корректно работать определенная модульная позиция, выводимая именно через макет... даже не представляю.

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

Заголовки модулей не отображаются

Автор web3.0

Ответов: 11
Просмотров: 2137
Последний ответ 17.10.2021, 02:18:03
от SalityGEN