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

zeus07

  • Давно я тут
  • 723
  • 9 / 0
Всем привет  ^-^
Разрабатываю сайт на своём шаблоне. Возникла необходимость использовать модальное окно на сайте. Для этого надо подключить его в своём шаблоне. Как я понял из официальной жокументации, надо использовать такое подключение в index.php шаблона:
Код
use Joomla\CMS\HTML\HTMLHelper::_('bootstrap.modal', '.selector', []);

Но выдаёт ошибку вот такую:
Код
0 - syntax error, unexpected '::' (T_PAAMAYIM_NEKUDOTAYIM), expecting ';' or ','

Подскажите пожалуйста, с чем это может быть связано? И как всё же корректно подключать бутстраповские компоненты?
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
здра.
просто addScript для самого скрипта и все.
инициализация окон по примерам на сайте
Код
var myModal = new bootstrap.Modal(document.getElementById('myForm'))
показ окна по клику (тут jquery как обработчик, но можешь на js)
Код
$(".modal-bt").click(function( event ) {
event.preventDefault()
myModal.show()
});
*

zeus07

  • Давно я тут
  • 723
  • 9 / 0
Не, согласен, что можно по старинке, скажем так )
Но хотелось бы всё-таки как-то использовать HTMLHelper для этого, ведь именно для этого он также прездназначен. Инфу брал из этой статьи на гитхабе: https://gist.github.com/dgrammatiko/efb3de4aa7cab4813a244f93f73cc0fd
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
ну такое.
если помимо Joomla ещё лендосы делать, то придется запоминать 2 синтаксиса.
имхо, проще нативным пользоваться, чем всякие костыли от Joomla. выйигрыш-то в чем?
*

zeus07

  • Давно я тут
  • 723
  • 9 / 0
Выигрыш в даном случае в овладевании новым синтаксисом и навыком) Поэтому и спросил, как правильно подключать именно через HTMLHelper
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Код
use Joomla\CMS\HTML\HTMLHelper::_('bootstrap.modal', '.selector', []);

А зачем тут use? Так надо:

Код
\Joomla\CMS\HTML\HTMLHelper::_('bootstrap.modal', '.selector', []);

.selector относится к селектору CSS для modal. Вы можете вызывать эту функцию несколько раз с разными селекторами CSS. Третий аргумент относится к параметрам, доступным для modal.

https://jpath.ru/docs/output/js-css/ispolzovanie-bootstrap-v-joomla-4
*

zeus07

  • Давно я тут
  • 723
  • 9 / 0
Код
use Joomla\CMS\HTML\HTMLHelper::_('bootstrap.modal', '.selector', []);

А зачем тут use? Так надо:

Код
\Joomla\CMS\HTML\HTMLHelper::_('bootstrap.modal', '.selector', []);

.selector относится к селектору CSS для modal. Вы можете вызывать эту функцию несколько раз с разными селекторами CSS. Третий аргумент относится к параметрам, доступным для modal.

https://jpath.ru/docs/output/js-css/ispolzovanie-bootstrap-v-joomla-4
Большое спасибо. Да, действительно, почему-то считал, что впереди надо использовать use. Теперь понял, благодарю.

Возможно подскажите ещё по такому вопросу. Как можно в модальное окно загрузить материал Joomla? Хотел бы выводить по клику
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Цитировать
Возможно подскажите ещё по такому вопросу. Как можно в модальное окно загрузить материал Joomla? Хотел бы выводить по клику
Создай новую тему, здесь же решили вопрос.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вопрос по шаблону Protostar для Joomla 5

Автор Mick_20

Ответов: 2
Просмотров: 735
Последний ответ 06.03.2025, 12:24:37
от web1
Где можно найти документацию по шаблону AS 002071 Free

Автор antipod

Ответов: 0
Просмотров: 750
Последний ответ 10.06.2024, 14:32:20
от antipod
Cassiopeia и Boostrap 5

Автор Ebelous

Ответов: 9
Просмотров: 1662
Последний ответ 04.03.2024, 19:31:03
от Ellis
Подключение к БД из отдельного файла

Автор kysin

Ответов: 2
Просмотров: 608
Последний ответ 29.05.2023, 13:54:37
от kysin
Вопрос по шаблону joomshaper

Автор palladin

Ответов: 5
Просмотров: 805
Последний ответ 26.10.2022, 13:17:21
от palladin