Новости 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 Ответов
  • 2452 Просмотров
*

Pris0neR

  • Новичок
  • 4
  • 0 / 0
Привязал Новостной модуль (meganews) к меню. Открывается страница с новостями (с модулем), но при открывании новости, открывается опять этот модуль и только снизу уже новость. Как сделать, чтобы модуль открывался только на одной странице, после нажатия пункта меню, и далее уже новости открывались без него?!
Спасибо.


( P.S.   вопрос менее важный.  При выставлении главного меню, типа меню - Материал, происходит на главной странице тоже самое. при нажатии на новость, она открывается на главной странице но совсем внизу. Но поставил тип - Список материалов категории, и нормально открывает, хочу сверху списка поставить модуль. но открывает так как я описал выше.)
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Чтобы такого не происходило, есть два варианта:
1. Для всех категорий и материалов создавать пункты меню.
2. Поставить AdvancedModulesManager и назначить более строгие условия вывода.

Один вопрос == одна тема. правила форума.

А как ваши вопросы связаны с локализацией?
*

Pris0neR

  • Новичок
  • 4
  • 0 / 0
Для всех категорий созданы пункты меню!
попробую AdvancedModulesManager, спасибо Shustry

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

Не работает псевдоним пункта меню

Автор djumfan

Ответов: 17
Просмотров: 13297
Последний ответ 13.12.2022, 11:29:28
от denism300
Частично не переводится модуль

Автор fireman

Ответов: 33
Просмотров: 10980
Последний ответ 04.04.2021, 10:37:59
от Akeksandr
Какой использовать модуль для меню с картинками?

Автор Евгений1980

Ответов: 7
Просмотров: 4025
Последний ответ 30.03.2020, 18:09:40
от Евгений1980
Как сделать, что бы в меню не было главной

Автор Grione

Ответов: 3
Просмотров: 2804
Последний ответ 31.12.2018, 17:48:07
от beliyadm
Модуль Jquery Jumpmenu JT (выпадающее меню) некорректно отображается

Автор Artur-ArtMetallUrall

Ответов: 52
Просмотров: 3968
Последний ответ 27.06.2018, 15:45:01
от lexxbry