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

S.t.A.m.

  • Осваиваюсь на форуме
  • 15
  • 6 / 0
При включении модулей в материал при помощи {loadposition user7} - модули отображаются без заголовков несмотря на то, что отображение заголовков включено и в параметрах модуля и на всякий случай в параметрах материала... Как лечить?
« Последнее редактирование: 07.03.2009, 23:19:42 от S.t.A.m. »
*

S.t.A.m.

  • Осваиваюсь на форуме
  • 15
  • 6 / 0
Re: loadposition не отображает заголовки!
« Ответ #1 : 08.03.2009, 17:04:43 »
Совсем никто не знает?!  :(
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: loadposition не отображает заголовки!
« Ответ #2 : 08.03.2009, 17:20:21 »
насколько покопался, причина в файле plugins\content\loadmodule.php строка 53
Код: php
$style	= $pluginParams->def( 'style', -2 );
Если заменить на существующий в шаблоне стиль отображения модуля - должно заработать, к примеру на строку
Код: php
$style	= $pluginParams->def( 'xhtml' );
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

S.t.A.m.

  • Осваиваюсь на форуме
  • 15
  • 6 / 0
Re: loadposition не отображает заголовки!
« Ответ #3 : 09.03.2009, 00:22:56 »
Хм... какая то мистика у меня вообще так идет:
Код
$style	= $pluginParams->def( 'style', -2 );
$title = $pluginParams->def( 'style', '*' );
plgContentProcessPositions( $row, $matches, $count, $regex, $style, $title );

далеее в функции plgContentProcessPositions:
Код
 		$load = str_replace( 'loadposition', '', $matches[0][$i] );
  $load = str_replace( '{', '', $load );
  $load = str_replace( '}', '', $load );
  $load = trim( $load );

//$modules = "<h3>". $title ."</h3>";
$modules .= plgContentLoadPosition( $load, $style );
$row->text = preg_replace( '{'. $matches[0][$i] .'}', $modules, $row->text );


Я не помню, что бы я вывод комментировал... я его раскомментировал, толку никакого - выходят нолики вместо тайтлов!
Вообщем проблема наполовину решена, осталось понять как из объекта модуля вытащить его Title... что то типа
Код
$title = $pluginParams->GetTitle;
- но этот вариант не прокатыват (((
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: loadposition не отображает заголовки!
« Ответ #4 : 09.03.2009, 03:31:31 »
хм, у меня 1.5.9 и код другой, приведенный мной вариант сработал, вывод модуля изменился
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

S.t.A.m.

  • Осваиваюсь на форуме
  • 15
  • 6 / 0
Re: loadposition не отображает заголовки!
« Ответ #5 : 09.03.2009, 03:49:49 »
Ясно! Спасибо! Видимо что то где то накосячил... буду востанавливать файлы из дистрибутива...
*

wounderer

  • Захожу иногда
  • 80
  • 3 / 0
Re: loadposition не отображает заголовки!
« Ответ #6 : 14.01.2010, 13:07:36 »
В настройках плагина loadmodule попробуй изменить вид обрамления.. Например на DIV, - мне помогло по крайней мере
*

firma777

  • Новичок
  • 4
  • 0 / 0
Re: loadposition не отображает заголовки!
« Ответ #7 : 11.05.2010, 23:35:08 »
насколько покопался, причина в файле plugins\content\loadmodule.php строка 53
Код: php
$style	= $pluginParams->def( 'style', -2 );
Если заменить на существующий в шаблоне стиль отображения модуля - должно заработать, к примеру на строку
Код: php
$style	= $pluginParams->def( 'xhtml' );
Спасибо, меня тоже интересоал этот вопрос.
*

archer1981

  • Захожу иногда
  • 285
  • 13 / 0
Re: loadposition не отображает заголовки!
« Ответ #8 : 28.03.2011, 00:40:42 »
Заголовки выводятся, но теперь непонятно как изменить стиль их вывода....
« Последнее редактирование: 28.03.2011, 00:57:32 от archer1981 »
http://walkspb.ru - Энциклопедия Санкт-Петербурга
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Заголовки HTTP

Автор julyca

Ответов: 11
Просмотров: 2271
Последний ответ 12.07.2015, 09:56:16
от altvvc
Как выровнять заголовки страниц по центру и увеличить

Автор artruslan

Ответов: 14
Просмотров: 4181
Последний ответ 04.12.2014, 21:06:48
от Shustry
Браузер Google Chrome не отображает надписи на кнопках

Автор Jercy

Ответов: 4
Просмотров: 3048
Последний ответ 31.03.2014, 20:04:25
от Jercy
Не отображает в статьях МАРКИРОВАННЫЙ СПИСОК

Автор sliverr_free

Ответов: 10
Просмотров: 3176
Последний ответ 15.08.2013, 14:21:30
от rishtik
Phoca Guestbook 1.4.3 компонент гостевой книги не отображает капчу

Автор Tykaram

Ответов: 5
Просмотров: 5419
Последний ответ 09.08.2013, 15:37:20
от Tykaram