Новости 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 Ответов
  • 3099 Просмотров
*

RAZORG1991

  • Захожу иногда
  • 349
  • 6 / 0
Может и не совсем правильно выразился в названии темы, но опишу так: пример модуля, в настройках которого есть такая штука Universal AJAX Live Search. Вот там где можно настроить цветовые схемы есть полоса градиента, цвет которой динамически меняется когда задаешь код цвета, а при нажатии на саму полосу градиента еще вылетает палитра цветов (я думаю многие поняли про что я), где уже можно прям курсором выставить понравившийся цвет.

Никто не подскажет как этот градиент и палитру можно также реализовать в настройках своего модуля?
*

xchesh

  • Захожу иногда
  • 277
  • 10 / 1
Нужен JS плагин.
Тип поля text, берете любой JS подбора цветов и подключаете к своему модулю, записываете в свое поле hex цвет. Все просто.
http://jscolor.com/
http://www.eyecon.ro/colorpicker/
http://www.colorpicker.com/
https://github.com/rightjs/rightjs-ui/tree/master/src/colorpicker/

Ну или выберите сами.
*

RAZORG1991

  • Захожу иногда
  • 349
  • 6 / 0
Нужен JS плагин.
Тип поля text, берете любой JS подбора цветов и подключаете к своему модулю, записываете в свое поле hex цвет. Все просто.
http://jscolor.com/
http://www.eyecon.ro/colorpicker/
http://www.colorpicker.com/
https://github.com/rightjs/rightjs-ui/tree/master/src/colorpicker/

Ну или выбирите сами.


А можно чуточку поподробнее с подключением, собственно куда его подключать, в какой файл? Меня больше интересует полоса градиента, а не колорпикер, тем более что в Joomla 3 уже появилась в настройках возможность подключения стандартного колорпикера, для этого всего лишь необходимо задать тип поля не text, а color. А вот как осуществить вот этот динамически меняющийся градиент?
*

xchesh

  • Захожу иногда
  • 277
  • 10 / 1
А можно чуточку поподробнее с подключением, собственно куда его подключать, в какой файл? Меня больше интересует полоса градиента, а не колорпикер, тем более что в Joomla 3 уже появилась в настройках возможность подключения стандартного колорпикера, для этого всего лишь необходимо задать тип поля не text, а color. А вот как осуществить вот этот динамически меняющийся градиент?
Для того чтобы узнать куда подключать к своему модулю файлы, нужно для начала прочитать что-нибудь из этого

А теперь я расскажу Вам, как подключить абсолютно любой JS, либо изобрести свой тип поля для модуля.

Создаете в модуле папку admin
Там будут лежать Ваши js и CSS фалы, которые хотите подключить.
Далее создаете в папке admin подпапку elements.
В папке elements создаете файл вашего типа поля, например asset.php


Код его будет вот такой:
Код: php
<?php
defined('JPATH_BASE') or die;
jimport('joomla.form.formfield');

class JFormFieldAsset extends JFormField {
        protected $type = 'asset';
        protected function getInput() {
                $doc = JFactory::getDocument();
                $doc->addStyleSheet(JURI::root().$this->element['path'].'файл_стилей.css');
                $doc->addScript(JURI::root().$this->element['path'].'файл_скрипта.js');
                return null;
        }
}
?>

Теперь добавляете в XML файл модуля новое поле с указанием path:
Код: xml
 <field type="asset" path="modules/mod_модуль/admin/" />

Архивируйте модуль, устанавливайте и будет Вам счастье.

P.S.: Все эти операции справедливы для Joomla 2.5, что насчет третьей версии - не испытывал.
« Последнее редактирование: 01.08.2013, 09:11:10 от xchesh »
*

RAZORG1991

  • Захожу иногда
  • 349
  • 6 / 0
Хорошо спасибо подумаем, кстати на счет разработки модулей уже читал не одну статью, но вот про это не было написано.

Но все же уточню, как я понял Вы дали ссылки в самом начале только на колорпикеры? Градиентов таких там нет? Я просто не силен в js чтобы самому писать подобные скрипты
*

xchesh

  • Захожу иногда
  • 277
  • 10 / 1
Хорошо спасибо подумаем, кстати на счет разработки модулей уже читал не одну статью, но вот про это не было написано.

Но все же уточню, как я понял Вы дали ссылки в самом начале только на колорпикеры? Градиентов таких там нет? Я просто не силен в js чтобы самому писать подобные скрипты
Есть статья на хабре про колорпикеры. На основании её можно сделать линию градиентную.
*

RAZORG1991

  • Захожу иногда
  • 349
  • 6 / 0
Есть статья на хабре про колорпикеры. На основании её можно сделать линию градиентную.

Ок спс поищем
*

RAZORG1991

  • Захожу иногда
  • 349
  • 6 / 0
Для того чтобы узнать куда подключать к своему модулю файлы, нужно для начала прочитать что-нибудь из этого

А теперь я расскажу Вам, как подключить абсолютно любой JS, либо изобрести свой тип поля для модуля.

Создаете в модуле папку admin
Там будут лежать Ваши js и CSS фалы, которые хотите подключить.
Далее создаете в папке admin подпапку elements.
В папке elements создаете файл вашего типа поля, например asset.php


Код его будет вот такой:
Код: php
<?php
defined('JPATH_BASE') or die;
jimport('joomla.form.formfield');

class JFormFieldAsset extends JFormField {
        protected $type = 'asset';
        protected function getInput() {
                $doc = JFactory::getDocument();
                $doc->addStyleSheet(JURI::root().$this->element['path'].'файл_стилей.css');
                $doc->addScript(JURI::root().$this->element['path'].'файл_скрипта.js');
                return null;
        }
}
?>

Теперь добавляете в XML файл модуля новое поле с указанием path:
Код: xml
 <field type="asset" path="modules/mod_модуль/admin/" />

Архивируйте модуль, устанавливайте и будет Вам счастье.

P.S.: Все эти операции справедливы для Joomla 2.5, что насчет третьей версии - не испытывал.

А возможно ли сделать точно так же только для шаблона? Только в path указать путь к нужным файлам из шаблона?
*

xchesh

  • Захожу иногда
  • 277
  • 10 / 1
А возможно ли сделать точно так же только для шаблона? Только в path указать путь к нужным файлам из шаблона?
Попробуйте, а потом расскажите нам.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вставка кода вызова модуля в тело шаблона другого модуля

Автор Dorfman

Ответов: 15
Просмотров: 2647
Последний ответ 19.11.2018, 21:45:54
от beliyadm
Нужна помощь в доработке модуля под Joomla 3

Автор kik84

Ответов: 5
Просмотров: 2795
Последний ответ 30.01.2018, 22:40:30
от Елeна
Модификация модуля lastet_news вывод времени перед заголовком

Автор Morphiss

Ответов: 9
Просмотров: 2568
Последний ответ 19.04.2016, 12:41:55
от spsyper
Создание платного модуля

Автор fiter

Ответов: 7
Просмотров: 2025
Последний ответ 04.08.2014, 18:27:05
от neo85r
[Решено] Автоматическое размешение модуля после установки

Автор asmuz

Ответов: 15
Просмотров: 7595
Последний ответ 21.07.2014, 21:59:18
от b2z