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

fimka

  • Осваиваюсь на форуме
  • 14
  • 0 / 0
Ребята, привет всем.

Есть проблема, чтобы понять ее суть, внимательно вчитайтесь в ее описание. Могу сказать, что рано или поздно может коснуться каждого, кто использует Joomla. Результат пренеприятнейший.

Проблема следующего рода:
1. Есть вложенный пункт главного меню (2-ой уровень. "Интересное">"Лимерики" http://www.englishelp.ru/interesting/limericks.html), пункт ссылается на статью (Стандартный шаблон материала отображает один материал).
2. Родительский для него пункт меню ("Интересное") ссылается на раздел (Отображает список категорий раздела).
3. Чтобы, при нажатии, на пункт меню "Интересное", раздел "Лимерики" также присутствовал в загруженной странице, была создана новая категория ("Лимерики"), содержащая, соответственно, только один материал.
Теперь, если нажать на пункт главного меню "Интересное", открывается его содержимое, где присутствует категория лимерики, нажимаем на нее, и видим такое содержимое http://www.englishelp.ru/interesting/31-limericks.html.

Проблема, имеет место быть, если пункт меню ссылается на статью.
Если кто-то сталкивался с подобным, знает или видит возможные пути решения, прошу откликнуться  ^-^

---
Мои варианты решения (не нравится ни один):
1. Перенаправление через .htaccess на нужный материал. (минус: длительная загрузка страницы).
2. Меняем тип меню, чтобы он ссылался не на материал, а на категорию (минус: дополнительный шаг, который должен пройти пользователь Клик по пункту меню>Видим категорию с одним разделом, клик по разделу).
*

daho

  • Захожу иногда
  • 138
  • 6 / 0
А остальные работающие пункты так же сделаны?
*

fimka

  • Осваиваюсь на форуме
  • 14
  • 0 / 0
А остальные работающие пункты так же сделаны?
Что значит остальные работающие?
Из главного меню пункты ссылаются на материалы по-разному, кто на категории, кто на разделы, а кто, как я описал выше, непосредственно на статьи. Проблема имеет место быть только, когда пункт меню ссылается на статью (см. выше).
Всего таких "проблемных" пунктов несколько
Переводчику / Базы Trados
Интересное / Скороговорки
Интересное / Пословицы
Интересное / Лимерики

С остальными пунктами, что ссылаются на разделы и категории все ок. Искренне надеюсь, что объясняю внятно.
*

SmokerMan

  • Гуру
  • 5290
  • 720 / 26
Была такая тема когда-то  ^-^ http://joomlaforum.ru/index.php/topic,45079.0.html
Если никто не ответит позже напишу как сделать так. Сейчас пока нету времени.
*

fimka

  • Осваиваюсь на форуме
  • 14
  • 0 / 0
Была такая тема когда-то  ^-^ http://joomlaforum.ru/index.php/topic,45079.0.html
Если никто не ответит позже напишу как сделать так. Сейчас пока нету времени.
Очень очень жду :)

Добавлено: Если кто-то понял проблему и его она тоже коснулась, то, как workaround, помогает следующее: Пункт главного меню, ссылающийся на статью (см. описание проблемы выше) должен иметь alias в точности такой же как у категории + id категории, в которой находится данная статья.
То есть, если материал находится в категории с alias "lymerics" и id 10, то alias пункта меню, ссылающегося на данную статью должен быть 10-lymerics
« Последнее редактирование: 16.05.2009, 21:07:22 от fimka »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

убрать из меню заголовки h3

Автор nexter

Ответов: 19
Просмотров: 8692
Последний ответ 03.02.2020, 18:49:47
от durte
При добавлении нового пункта меню не отображается содержимое

Автор Denko

Ответов: 2
Просмотров: 3815
Последний ответ 16.01.2020, 18:40:55
от Denko
Не нажимается пункт меню на мобильной версии

Автор Sensession

Ответов: 7
Просмотров: 5466
Последний ответ 04.01.2020, 16:45:27
от xpank
Не отображаются пункты в меню

Автор physic

Ответов: 20
Просмотров: 23939
Последний ответ 20.09.2019, 16:54:01
от beliyadm
Как в ARI Ext Menu добиться работы параметра "Показать в меню"?

Автор vasmed

Ответов: 1
Просмотров: 4162
Последний ответ 01.03.2019, 11:12:18
от vasmed