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

Tureckiy

  • Осваиваюсь на форуме
  • 35
  • 0 / 0
Вызов плагина!
« : 10.08.2010, 23:36:39 »
Подскажите, как впрограмно вызвать конктретный плагин из категории "system"? Дело в том что при сохранении контента кроном надо вызвать системный плагин (в данном случае для обработки alias)! Для плагина типа "content" - вопросов нет, но вот для плагина категории "system" пока не знаю!  :( Кто сталкиваося с таким вызовом?
*

userxp

  • Живу я здесь
  • 2019
  • 403 / 6
  • Злой и ужасный бармалей
Re: Вызов плагина!
« Ответ #1 : 11.08.2010, 00:41:13 »
в смысле? а какая разница?
Как правильно задавать вопрос службе технической поддержки  yes!
SGA CM 7.2.0 RC0 KANG Build GWK74 + s95allinonescript + CWM 5.0.2.6 + Modem XWKT3
*

Tureckiy

  • Осваиваюсь на форуме
  • 35
  • 0 / 0
Re: Вызов плагина!
« Ответ #2 : 11.08.2010, 09:35:14 »
Цитировать
в смысле? а какая разница?
Ну при сохранении  плагины content вызываются
Код
$dispatcher 	= & JDispatcher::getInstance();
JPluginHelper::importPlugin('content');
...
$result = $dispatcher->trigger('onBeforeContentSave', array(&$row, $isNew));
а системные вызываются где то на этапе
Код
$row->store()
(print_r ми приверял момент вызова)
А когда я в сохраняю так же
Цитировать
if (!$content->store()) {
JError::raiseWarning( 500, $db->getError() );   
}
ничего не происходит (в плане вызова плагина)
*

userxp

  • Живу я здесь
  • 2019
  • 403 / 6
  • Злой и ужасный бармалей
Re: Вызов плагина!
« Ответ #3 : 11.08.2010, 14:41:39 »
системные плагины находятся в папке 'system', соотв. JPluginHelper::importPlugin('system');
а сделать trigger на onBeforeContentSave для системного плагина.... ну это как доить корову пылесосом

а системные вызываются где то на этапе
Код
$row->store()
плагины вызываются на СОБЫТИЯ

зы. впервые слышу про системный плагин для обработки alias-а. какая его задача?
Как правильно задавать вопрос службе технической поддержки  yes!
SGA CM 7.2.0 RC0 KANG Build GWK74 + s95allinonescript + CWM 5.0.2.6 + Modem XWKT3
*

Tureckiy

  • Осваиваюсь на форуме
  • 35
  • 0 / 0
Re: Вызов плагина!
« Ответ #4 : 11.08.2010, 22:33:57 »
системные плагины находятся в папке 'system', соотв. JPluginHelper::importPlugin('system');
а сделать trigger на onBeforeContentSave для системного плагина.... ну это как доить корову пылесосом
плагины вызываются на СОБЫТИЯ

зы. впервые слышу про системный плагин для обработки alias-а. какая его задача?
Нет, ну в классе JTable в методе store() наверняка как то плагин вызывается (кстати надо посмотреть). А плагин просто из кирилицы латиницу aliesa делает!
*

userxp

  • Живу я здесь
  • 2019
  • 403 / 6
  • Злой и ужасный бармалей
Re: Вызов плагина!
« Ответ #5 : 11.08.2010, 22:42:02 »
нет. не вызывается.
а в наследниках - сложно сказать, надо ковырять код.

есть событие onSave в группе editors.
я пока не нашел где эта группа вызывается.

а тебе где надо? с фронта или в админке?
Как правильно задавать вопрос службе технической поддержки  yes!
SGA CM 7.2.0 RC0 KANG Build GWK74 + s95allinonescript + CWM 5.0.2.6 + Modem XWKT3
*

era

  • Администратор
  • 1588
  • 392 / 5
  • В туалете лучше быть пользователем, чем админом.
Re: Вызов плагина!
« Ответ #6 : 11.08.2010, 22:55:56 »
а чё-ж task в Request и Post не проверить в плане того что-бы узнать что сейчас будет? типа если option == 'com_content' и task == 'edit' или task == 'apply' или task == 'save', то подправить данные что пришли через POST
*

userxp

  • Живу я здесь
  • 2019
  • 403 / 6
  • Злой и ужасный бармалей
Re: Вызов плагина!
« Ответ #7 : 11.08.2010, 22:58:24 »
интересная мысль.
оч могет быть.
Как правильно задавать вопрос службе технической поддержки  yes!
SGA CM 7.2.0 RC0 KANG Build GWK74 + s95allinonescript + CWM 5.0.2.6 + Modem XWKT3
*

rubasket

  • Захожу иногда
  • 346
  • 13 / 1
  • RuBasket.com
Re: Вызов плагина!
« Ответ #8 : 11.08.2010, 23:07:12 »
$article->alias на onbeforesavecontent ?
Только я знаю,что могу (C) Джон Локк 
Why him ?Mmm? What  about me? БЕНЖАМИН Л
*

userxp

  • Живу я здесь
  • 2019
  • 403 / 6
  • Злой и ужасный бармалей
Re: Вызов плагина!
« Ответ #9 : 11.08.2010, 23:15:00 »
точно. есть такое событие.
можно написать обычный плагин группы content
Как правильно задавать вопрос службе технической поддержки  yes!
SGA CM 7.2.0 RC0 KANG Build GWK74 + s95allinonescript + CWM 5.0.2.6 + Modem XWKT3
*

Tureckiy

  • Осваиваюсь на форуме
  • 35
  • 0 / 0
Re: Вызов плагина!
« Ответ #10 : 12.08.2010, 11:32:54 »
точно. есть такое событие.
можно написать обычный плагин группы content
Как вариант! Еще можно попробовать перенести (сделать копию) плагина в категорию 'content'  - и проблема сама собой отпадет!
*

rubasket

  • Захожу иногда
  • 346
  • 13 / 1
  • RuBasket.com
Re: Вызов плагина!
« Ответ #11 : 12.08.2010, 11:54:18 »
смысл? я уже написал,как можно транслитировать алиас до сохранения контента.
Только я знаю,что могу (C) Джон Локк 
Why him ?Mmm? What  about me? БЕНЖАМИН Л
*

Tureckiy

  • Осваиваюсь на форуме
  • 35
  • 0 / 0
Re: Вызов плагина!
« Ответ #12 : 12.08.2010, 12:54:42 »
смысл? я уже написал,как можно транслитировать алиас до сохранения контента.
типа на событие onbeforesavecontent вызвать системный плагин таким способом ?
Код
JPluginHelper::importPlugin('system');
*

rubasket

  • Захожу иногда
  • 346
  • 13 / 1
  • RuBasket.com
Re: Вызов плагина!
« Ответ #13 : 12.08.2010, 13:05:45 »
нет,
$article->alias=funcAlias($article->alias);
function funcAlias($text){........ }
так понятно?
$article->alias-это и есть алиас статьи на онбефосейвконтент
Только я знаю,что могу (C) Джон Локк 
Why him ?Mmm? What  about me? БЕНЖАМИН Л
*

Tureckiy

  • Осваиваюсь на форуме
  • 35
  • 0 / 0
Re: Вызов плагина!
« Ответ #14 : 12.08.2010, 13:24:09 »
так понятно?
$article->alias-это и есть алиас статьи на онбефосейвконтент
нет, что ты имел ввиду под строчкой? $article->alias-это и есть алиас статьи на онбефосейвконтент
Если онбефосейвконтент - это и есть событие, на которое я могу вызвать плагины из категории системные! (если они конечно вызовятся по аналогии с плагинами конетнта)
А в функции function funcAlias($text){........ } что по твоему писать надо? (если я кирилицу функуиями php не обработаю !)
*

rubasket

  • Захожу иногда
  • 346
  • 13 / 1
  • RuBasket.com
Re: Вызов плагина!
« Ответ #15 : 12.08.2010, 13:37:39 »
хватит писать о каких-то вызовах,я уже вам решил задачу легким путем,если непонятно-сам сделаю плагин рублей за 300
Только я знаю,что могу (C) Джон Локк 
Why him ?Mmm? What  about me? БЕНЖАМИН Л
*

userxp

  • Живу я здесь
  • 2019
  • 403 / 6
  • Злой и ужасный бармалей
Re: Вызов плагина!
« Ответ #16 : 12.08.2010, 13:38:05 »
Как вариант! Еще можно попробовать перенести (сделать копию) плагина в категорию 'content'  - и проблема сама собой отпадет!
куда отпадет?
системные плагины не отрабатывают событие onBeforeSaveContent
для этого надо написать такой плагин.
Как правильно задавать вопрос службе технической поддержки  yes!
SGA CM 7.2.0 RC0 KANG Build GWK74 + s95allinonescript + CWM 5.0.2.6 + Modem XWKT3
*

SmokerMan

  • Гуру
  • 5290
  • 720 / 26
Re: Вызов плагина!
« Ответ #17 : 12.08.2010, 13:50:08 »
Подскажите, как впрограмно вызвать конктретный плагин из категории "system"? Дело в том что при сохранении контента кроном надо вызвать системный плагин (в данном случае для обработки alias)! Для плагина типа "content" - вопросов нет, но вот для плагина категории "system" пока не знаю!  :( Кто сталкиваося с таким вызовом?
Зачем так делать не понятно, еще вешать крон :)
Вам уже написали ответ. Пишется стандартный контент плагин на событие onBeforeSave. И никаких системных плагинов и тем более кронов не нужно.
*

Tureckiy

  • Осваиваюсь на форуме
  • 35
  • 0 / 0
Re: Вызов плагина!
« Ответ #18 : 12.08.2010, 14:06:41 »
Зачем так делать не понятно, еще вешать крон :)
Вам уже написали ответ. Пишется стандартный контент плагин на событие onBeforeSave. И никаких системных плагинов и тем более кронов не нужно.
На этом наверно и остановлюсь, спасибо всем кто пытался помочь!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Дополнительные параметры пунктов меню для плагина

Автор enshtein

Ответов: 3
Просмотров: 3096
Последний ответ 06.11.2014, 16:48:17
от lebmarg
Доработка плагина

Автор Ragnos

Ответов: 19
Просмотров: 2205
Последний ответ 07.07.2014, 16:14:16
от zomby6888
Нужна помощь в разработке плагина. Цена?

Автор jason1311

Ответов: 0
Просмотров: 1240
Последний ответ 15.05.2014, 18:20:10
от jason1311
Как запустить выполнение плагина принудительно из модуля?

Автор NemoNik

Ответов: 8
Просмотров: 2300
Последний ответ 14.05.2014, 17:35:04
от NemoNik
Получить значение параметра плагина в js

Автор AlekVolsk

Ответов: 24
Просмотров: 2095
Последний ответ 30.04.2014, 18:13:33
от Aleks.Denezh