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

foreach

  • Осваиваюсь на форуме
  • 43
  • 1 / 0
Уважаемые форумчане, столкнулся с проблемой.
Есть стандартный модуль поиска. Он виден на всех страницах(во всех меню). Но вот результаты поиска выдает там где находился пользователь в данный момент(в каком меню). То есть если на главной, то и результаты выводятся на главной, ниже всех модулей которые формируют контент главной страницы.
Можно ли как то сделать, что бы результаты выводились на отдельной странице? Ну то есть гдебы ни нажал кнопку "Искать" происходил переход на страницу с выводом результатов поиска.
« Последнее редактирование: 16.11.2012, 13:46:38 от smart »
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
Можно создать пункт меню типа «Форма поиска и список результатов поиска» и тогда результаты будут открываться на этой странице. А можно просто в параметрах модуля поиска задать параметр Itemid, указав идентификатор пункта меню, который будет активирован при отображении результатов поиска по сайту.
*

Ohar

  • Новичок
  • 2
  • 0 / 0
Большое спасибо, заработало.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

как выводить категории на главной странице.

Автор makarovse

Ответов: 7
Просмотров: 2855
Последний ответ 03.04.2022, 19:50:42
от THE KILLERS
У вас нет прав на доступ к данной странице по прямой ссылке (#d).

Автор fedragon

Ответов: 41
Просмотров: 41907
Последний ответ 11.05.2018, 10:56:05
от beagler
Навигация на странице. Почему не все ссылки работают?

Автор Ирина Поехали

Ответов: 0
Просмотров: 1921
Последний ответ 24.01.2018, 11:58:14
от Ирина Поехали
Порядок плагинов на странице

Автор intcorp

Ответов: 5
Просмотров: 2094
Последний ответ 26.04.2017, 23:51:10
от UN_Tony
Как изменить отображение материала на главной странице?

Автор pashafox

Ответов: 1
Просмотров: 1517
Последний ответ 06.03.2017, 16:02:20
от darkghost