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

Tamplier

  • Новичок
  • 5
  • 0 / 0
Где в Joomla хранится номер текущего уровня в меню - в какой переменной?
Задача состоит в том чтобы отображать некий модуль в зависиости от уровня текущего пункта в меню.
Я использую компонент Advanced Module Manager http://extensions.joomla.org/extensions/10307 и в нем есть опция отображения в зависимости от PHP выражения.
Так вот в поле сравнения этой опции нужно вписать что-то вроде
return ($MenuLevel > 1 && $MenuLevel < 5);
где $MenuLevel -  текущий уровень в меню. Приведенный пример будет отображать модуль только в тех пунктах меню которые находятся во 2-4 уровнях этого меню.
Теперь собственно вопрос: Что вписать вместо $MenuLevel? Какая переменная хранит текущий уровень текущего меню?
« Последнее редактирование: 05.12.2010, 22:06:33 от Tamplier »
*

Tamplier

  • Новичок
  • 5
  • 0 / 0
Неужели никто не знает? :( Подскажите хотя-бы в каком направлении копать.
*

DSergeev™

  • Захожу иногда
  • 64
  • 1 / 0
  • Не возжелай себе рейтинга другого блоггера
отключаем SEF и смотрим на урл

/index.php?option=com_content&view=section&layout=blog&id=2&Itemid=4

Панель администратора Joomla -> Все меню -> Главное меню -> Самая правая колонка под названием Itemid

для меню отличных от главного, делать по аналогии
*

Tamplier

  • Новичок
  • 5
  • 0 / 0
Спасибо DSergeev™. Но это немного не то, что требовалось.
Я обратился напрямую к разработчику Advanced Module Manager. И вот что он мне ответил:
Цитировать
Hmm, I think this in the php field could do the trick. I know, a little complex:
Код
$showonlevel = '2,3';

$getMenuParent = create_function( '$id',
 '$db =& JFactory::getDBO();
 $query = "SELECT parent FROM #__menu WHERE id = ".(int) $id." LIMIT 1";
 $db->setQuery( $query );
 return $db->loadResult();
');
$level = 0;
$menuid = JRequest::getInt( 'Itemid' );
while ( $menuid ) {
 $level++;
 $menuid = $getMenuParent( $menuid );
}
return ( in_array( $level, explode( ',', $showonlevel ) ) );
You can set the first variable to what you want. level 1 would be the top level. level 2 would be a sub level, level 3 a sub-sublevel, etc.
So in above code, the module would show on level 2 and 3 (sub and sub-sub menu items).
Для тех кто использует Advanced Module Manager, такой финт ушами будет интересен!  yes!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

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

Автор nexter

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

Автор Denko

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

Автор Sensession

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

Автор physic

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

Автор vasmed

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