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

mila_serdnaya

  • Захожу иногда
  • 432
  • 3 / 0
Здравствуйте!
Зарегистрированный пользователь Чебурашка публикует на сайте материал. К примеру, 5 статей о коровах и 5 статей о помидорах.
Чебурашка не простой. У него есть свой личный кабинет. Этот кабинет ему сделал добрый тётенька Администратор (путём создания меню, которое видят только зарегистрированные пользователи).
Один из пунктов этого меню называется "Комментарии". Чебурашка хочет, чтобы при нажатии на на этот пункт меню, он видел список всех комментариев, которые оставили другие пользователи под его статьями, потому как Чебурашка личность любопытная.

Помогите, пожалуйста, доброму тётеньке Администратору, пока он не стал злой дяденькой. Что нужно сделать для решения поставленной задачи (пункт меню с названием Комментарии создан (тип - материал, далее планируется в материал вставить модуль, который позволит отображать список всех комментариев к статьям автора), jcomments установлен и настроен, несколько комментариев под статьями оставлены)?
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Выпадающий список в jcomments

Автор Ахмат

Ответов: 19
Просмотров: 4086
Последний ответ 29.03.2023, 17:27:47
от Marina1986
Общее количество комментариев, оставленных конкретным пользователем

Автор Vlad1

Ответов: 9
Просмотров: 3414
Последний ответ 28.09.2022, 23:21:05
от Helios
Модуль для вывода последних комментариев из JComments

Автор draff

Ответов: 7
Просмотров: 3554
Последний ответ 16.09.2021, 21:35:48
от draff
Вывести один и тот же список комментариев плагина jcomments на разных материалах

Автор max_max

Ответов: 17
Просмотров: 2185
Последний ответ 16.10.2020, 20:48:50
от gartes
Выпадающий список в поле "Тема"

Автор Ахмат

Ответов: 7
Просмотров: 980
Последний ответ 08.09.2020, 20:22:03
от voland