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

lukum

  • Осваиваюсь на форуме
  • 37
  • 0 / 0
Где и как изменить привязку модуля к пункту меню в базе данных стоит 1.5.22 ?

Поясню, в менеджере модулей мы создаем модуль, выбираем в каком пункте и какого меню он должен показываться. А вот где эта привязка происходит в базе данных я не нашел. Подскажите, пожалуйста, где привязывается модуль в базе данных и где можно изменить эту привязку. Все могу изменить, а вот привязку нет.
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
А зачем ее менять в базе, когда можно в административной панели?
*

lukum

  • Осваиваюсь на форуме
  • 37
  • 0 / 0
А вообще это возможно сделать?
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
А вообще это возможно сделать?
хм, а вот это кто написал - я или вы:
в менеджере модулей мы создаем модуль, выбираем в каком пункте и какого меню он должен показываться
*

lukum

  • Осваиваюсь на форуме
  • 37
  • 0 / 0
Если из админки привязывать, то понятно. Но я хочу понять в базе данных, где находится привязка?
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
Информация хранится в таблице jos_modules_menu (хотя мне кажется это без проблем можно было понять просто посмотрев список таблиц БД).
*

lukum

  • Осваиваюсь на форуме
  • 37
  • 0 / 0
Если модуль привязан к нескольким пунктам, то почему-то виден id только одного из них.
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
Хм, я думаю вам стоит почитать немного про реляционные базы данных, связи 1:N, M:N и т.д... Честно, мне кажется здесь не место для лекций по теории баз данных.
*

petrovich_1

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
хм, а вот это кто написал - я или вы:

я не пойму как выбрать пункт меню для модуля
*

brumy

  • Новичок
  • 1
  • 0 / 0
 У меня похожий вопрос. Не могу избавиться от бокового меню пользователя на странице материала Joomla 3. Если задаю привязку "На всех страницах, кроме" модуль появляется на всех и на кроме тоже. Если только на указанных, он все равно на всех появляется. Причем в базе данных он отвязан, т.е.  номеру модуля меню сопоставлен отрицательный номер меню нужной страницы. Сделала для этой страницы свой шаблон и попыталась в этом шаблоне задать модуль в несуществующей позиции - он везде исчезает. Не хочется пользоваться Advanced Module Manager и пр., так как наверняка можно обойтись. Где-то какая-то настройка не так выставлена. Подскажите пожалуйста.
*

KKAAZZOO

  • Живу я здесь
  • 2288
  • 119 / 9
Сделайте отдельный пункт меню с этим материалом.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

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

Автор nexter

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

Автор Denko

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

Автор Sensession

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

Автор physic

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

Автор vasmed

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