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

Ellin

  • Осваиваюсь на форуме
  • 15
  • 0 / 0
Стоит следующая задача...
Есть модуль "меняющаяся картинка" в нём необходимо чтоб разместился модуль с текстом и кнопкой перехода....
Нечто похожее на вот это - http://www.hansgrohe.com
Какими приложениями лучше воспользоваться для помещения модуля в модуль? как решить вопрос с кнопкой (прописывать отд млдуль, либо переделать к примеру OrderButton либо как тут http://artwebmaster.ru/ru/webmasters/dynamic-graphic-button.html)?
чем воспользоваться и в каком порядке?
заранее спс)
*

Ellin

  • Осваиваюсь на форуме
  • 15
  • 0 / 0
Попробовал...
Есть проблема
ModulesAniwhere не вставляется в randomimage
Вписать вручную в шаблон модуля не выходит...
Итого.. пробую сделать следующую задачу:
переделываю модуль такого типа...
Цитировать
defined('_JEXEC') or die('Restricted access');

$document = &JFactory::getDocument();

// добавление javascript и CSS к заголовку документа
$document->addScript( 'modules/mod_orderbutton/js/jquery.js' );
// если активное изображение включено
if($params->get('active_image') == 0) :
{
   $document->addScript( 'modules/mod_orderbutton/js/active_image.js' );
}
endif;

// Include the syndicate functions only once
require_once dirname(__FILE__).DS.'helper.php';

$event = modOrderButtonHelper::getEvent($params);
$type_button = modOrderButtonHelper::getTypeButton($params);
$type_button_active = modOrderButtonHelper::getTypeButtonActive($params);

require(JModuleHelper::getLayoutPath('mod_orderbutton'));
дабы предусмотреть то, что данный модуль появляется на фоне меняющихся картинок...
к примеру если он будут меняться таким скриптом как тут:
http://www.sql.ru/forum/actualthread.aspx?tid=682755&pg=1#7462546
Получается хрень полная)

подскажи плз чайнику куда я пошёл не туда))))))
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
лично у меня нет никакого желания разбираться в сторонних кодах.
если так не получается, ищи готовый модуль слайдшоу, благо они есть
к примеру, тут
http://extensions.joomla.org/extensions/photos-a-images/images-slideshow]http://extensions.joomla.org/extensions/photos-a-images/images-slideshow]http://extensions.joomla.org/extensions/photos-a-images/images-slideshow
*

Ellin

  • Осваиваюсь на форуме
  • 15
  • 0 / 0
лично у меня нет никакого желания разбираться в сторонних кодах.
если так не получается, ищи готовый модуль слайдшоу, благо они есть
к примеру, тут
http://extensions.joomla.org/extensions/photos-a-images/images-slideshow
битая ссылка...(
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
)))
ну так глаза можно и открыть - утро уже наступило ).
видно же, что косяк в начале- фтп, вместо http ))).
исправил. посмоттри на модуль от рокетов, к примеру
*

Ellin

  • Осваиваюсь на форуме
  • 15
  • 0 / 0
лично у меня нет никакого желания разбираться в сторонних кодах.
если так не получается, ищи готовый модуль слайдшоу, благо они есть
к примеру, тут
http://extensions.joomla.org/extensions/photos-a-images/images-slideshow]http://extensions.joomla.org/extensions/photos-a-images/images-slideshow]http://extensions.joomla.org/extensions/photos-a-images/images-slideshow
сорь... загрузилось.. щас пропробую... спасибо за помощь
*

Ellin

  • Осваиваюсь на форуме
  • 15
  • 0 / 0
)))
ну так глаза можно и открыть - утро уже наступило ).
видно же, что косяк в начале- фтп, вместо http ))).
исправил. посмоттри на модуль от рокетов, к примеру
сорри что переспрашиваю...)
вопрос по изменению модуля от рокетов...
Цитировать
// no direct access
defined('_JEXEC') or die('Restricted access');
// Include the syndicate functions only once
require_once (dirname(__FILE__).DS.'helper.php');

$imagePath    = modRokSlideshowHelper::cleanDir($params->get( 'imagePath', 'images/stories/fruit' ));
$sortCriteria = $params->get( 'sortCriteria', 0);
$sortOrder = $params->get( 'sortOrder', 'asc');
$sortOrderManual = $params->get( 'sortOrderManual', '');

if (trim($sortOrderManual)!= "")
   $images = explode(",", $sortOrderManual);
else
   $images = modRokSlideshowHelper::imageList($imagePath, $sortCriteria, $sortOrder);

if (count($images) > 0) modRokSlideshowHelper::loadScripts($params, $imagePath, $images);
require(JModuleHelper::getLayoutPath('mod_rokslideshow'));
Это рнр файл...
текст не вставляется...
модуль ModulesAniwhere тоже...
куда дальше смотреть?...
*

Ellin

  • Осваиваюсь на форуме
  • 15
  • 0 / 0
урааа)))
Разобрался!)
Спасип!)
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Чем лучше всего делать резервные копии сайта?

Автор 7Azimuth

Ответов: 115
Просмотров: 59031
Последний ответ 29.11.2023, 14:41:12
от sivers
модуль Newsflash: как вывести дату?

Автор joomloid

Ответов: 5
Просмотров: 3669
Последний ответ 03.04.2019, 12:25:27
от pH43
Как отредактировать модуль mod_yoo_slider?

Автор vitaliy4us

Ответов: 0
Просмотров: 2579
Последний ответ 06.12.2017, 16:14:45
от vitaliy4us
Модуль "Случайное изображение"

Автор irina 4444

Ответов: 16
Просмотров: 8578
Последний ответ 26.05.2017, 12:47:56
от gvg
Как увиличить максимальное количество символов в стандартном модуле (mod_custom)?

Автор genkey

Ответов: 0
Просмотров: 1459
Последний ответ 27.04.2017, 14:41:22
от genkey