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

ValeryB

  • Захожу иногда
  • 384
  • 31 / 2
У меня вопрос по выбору типа меню для родительского пункта.
Почему нет пустого типа, что бы использовать его для родительского пункта. Если ни один из предлагаемых вариантов не устраивает?
Например на сайте могут использоваться для разного материала вывод средствами разных фото галерей.
Родительский пункт что-то типа "Фото галереи" и далее вывод материалов с подключениям к дочерним пунктам нужных конкретных типов.
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
есть пустой тип, называется разделитель\separator, вставляет просто span class="separator" без ссылки
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

ValeryB

  • Захожу иногда
  • 384
  • 31 / 2
А разве сепаратор, это не линия в меню? Для деления меню на логические блоки?
Попробовал вместо линии ввести текст. Текст отображается, но не кликабелен. На дочерние пункты переход не дает.
« Последнее редактирование: 12.04.2010, 16:37:08 от ValeryB »
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
А разве сепаратор, это не линия в меню? Для деления меню на логические блоки?
ну так сделайте и будет видно, еще раз - это просто текст, получается вот такой вот код
Код: html4strict
<li class="item59"><span class="separator"><span>Текст разделителя</span></span></li>
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

ValeryB

  • Захожу иногда
  • 384
  • 31 / 2
ну так сделайте и будет видно
Я же написал. Ввел текст, но он не реагирует на мышь и перехода к дочерним пунктам в таком случае нет.
Цитировать
еще раз - это просто текст, получается вот такой вот код
Код: html4strict
<li class="item59"><span class="separator"><span>Текст разделителя</span></span></li>
Это код сепаратора в Joomla или надо куда вносить?
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Я же написал. Ввел текст, но он не реагирует на мышь и перехода к дочерним пунктам в таком случае нет.
а оно и не должно реагировать, если вы хотите делать раскрывающееся меню по клику без перехода - то стандартный модуль этого не умеет, ищите сторонний.
А так можно в настройках модуля сделать показ дочерних пунктов всегда и будут показаны в иерархии
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

ValeryB

  • Захожу иногда
  • 384
  • 31 / 2
Об том и речь. Просто все родительские пункты в стандартном меню Joomla обязательно должны куда-то вести. И при нажатии открывается другая страница. А так, что бы при нажатии раскрывались дочерние пункты - такого нет.
Иногда есть потребность объединить ряд родственных пунктов меню одним заголовком, который будет в родительском уровне меню, а сами пункты убрать в подменю (дочерний уровень), которое выпадает (или открываются пункты) при нажатии на заголовок родительского меню.
Например как в папках Windows, нажатие в меню на пункт "Файл" не вызывает никаких изменений, кроме как выпадения подменю со своими пунктами.
Или вот здесь http://www.goodwinpress.ru/?p=330 типа аккордеон-меню, нажатие на родительский пункт не вызывает переходов, а лишь дает доступ к следующему уровню.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

убрать из меню заголовки 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