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

rsn

  • Давно я тут
  • 520
  • 34 / 3
Коллеги, приветствую!
Сориентируйте, пожалуйста:
это я чего-то не понимаю и делаю что-то не так
или
это у всех не работают метаданные из настроек пункта меню Virtuemat?

Неужели так и есть и все смирились? ^-^

Сделал пункт меню "VirtueMart » Производители".
При его настройке во вкладке "Метаданные" заполнил Description и Keywords.
И что вы думаете? :) И ничего!
Они не применяются.

При этом, если посмотреть на объект $this (в файле _шаблон/html/com_virtuemart/manufacturer/defalt.php)
Код
print_r($this)
то свои метаданные в объекте можно увидеть на странице:
Спойлер
[свернуть]

Но как их оттуда вывести? Подскажите, пожалуйста )


P.S. Другие пункты меню VirtueMart, по-моему, тоже не дружат с метаданными...
VirtueMart 3.4.2, Joomla 3.9.1.
Возможно, будет интересно: Интеграция с Ozon
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
Re: Метаданные пункта меню в VirtueMart
« Ответ #1 : 24.12.2018, 15:55:46 »
Но как их оттуда вывести? Подскажите, пожалуйста )
Код: php
$params = $this->state->get('parameters.menu');
echo $params->get('menu-meta_description');
echo $params->get('menu-meta_keywords');
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

rsn

  • Давно я тут
  • 520
  • 34 / 3
Re: Метаданные пункта меню в VirtueMart
« Ответ #2 : 25.12.2018, 08:17:18 »
Код: php
$params = $this->state->get('parameters.menu');
echo $params->get('menu-meta_description');
echo $params->get('menu-meta_keywords');

Спасибо за наводку, NewUsers!
Но что-то именно так не заработало.

Разместил в файле _шаблон/html/com_virtuemart/manufacturer/default.php
Только первая строчка уже приводит к ошибке:
0 - Call to a member function get() on null

Методом великого научного тыка пришёл к такому коду для этой цели:
Код
$menu_params = $this->_models[manufacturer]->get('state')->{'parameters.menu'};
echo $menu_params->get('menu-meta_description');
echo $menu_params->get('menu-meta_keywords');

Собственно, вопрос, кажется, на этом успешно решён.
Осталось только задать эти метаданные странице.

Итоговый франгмент кода для вставки в указанный файл:
Код
<?php
        $menu_params = $this->_models[manufacturer]->get('state')->{'parameters.menu'};
        //echo $menu_params->get('menu-meta_description');
        //echo $menu_params->get('menu-meta_keywords');
        $document = JFactory::getDocument();
        $document->setDescription($menu_params->get('menu-meta_description'));
        $document->setMetadata('keywords', $menu_params->get('menu-meta_keywords'));
?>

Если будут замечания или предложения, буду благодарен.
Не исключаю, что это можно улучшить с точки зрения оптимизации.
« Последнее редактирование: 25.12.2018, 08:26:27 от rsn »
Возможно, будет интересно: Интеграция с Ozon
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
Re: Метаданные пункта меню в VirtueMart
« Ответ #3 : 25.12.2018, 09:01:36 »
А чем тебе это не устраивает? (https://yadi.sk/d/Z6eAqb90bFouSw) - описание и ключевые слова можно указать в настройках самого производителя...
Если хочется именно с настроек пункта меню выводить то лучше сделать вот так
Код: php
$active = JFactory::getApplication()->getMenu()->getActive();
и потом выводить вот так
Код: php
echo $active->params->get('menu-meta_description');
« Последнее редактирование: 25.12.2018, 09:09:35 от NewUsers »
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

rsn

  • Давно я тут
  • 520
  • 34 / 3
Re: Метаданные пункта меню в VirtueMart
« Ответ #4 : 25.12.2018, 11:35:16 »
А чем тебе это не устраивает? (https://yadi.sk/d/Z6eAqb90bFouSw) - описание и ключевые слова можно указать в настройках самого производителя...
Я использую пункт меню не для одного конкретного производителя, а для вывода всех производителей. Вот при выводе всех нужные мета из пункта меню не выводятся стандартно.

Цитировать
$active = JFactory::getApplication()->getMenu()->getActive();
echo $active->params->get('menu-meta_description');
Понял. Спасибо! Попробую.
Возможно, будет интересно: Интеграция с Ozon
*

rsn

  • Давно я тут
  • 520
  • 34 / 3
Re: Метаданные пункта меню в VirtueMart
« Ответ #5 : 25.12.2018, 12:07:05 »
Там, оказывается, и Title страницы выводился какой-то непонятный (не от пункта меню): "Страница производителя".

В итоге, с учётом вышеизложенного остановился на этом:

Код
<?php        
        $document = JFactory::getDocument();
        $active = JFactory::getApplication()->getMenu()->getActive();
        $document->setDescription($active->params->get('menu-meta_description'));
        $document->setMetadata('keywords', $active->params->get('menu-meta_keywords'));
        $document->setTitle($active->title.' - '.JFactory::getApplication()->getCfg('sitename'));
?>
Возможно, будет интересно: Интеграция с Ozon
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Расчёт стоимости товара в VirtueMart за периметр

Автор NIKOLY

Ответов: 0
Просмотров: 473
Последний ответ 04.07.2025, 09:18:31
от NIKOLY
VirtueMart 3 Отображать только товары в наличии!

Автор GaziroFFka

Ответов: 4
Просмотров: 3983
Последний ответ 06.06.2023, 13:55:13
от Akeksandr
SP VirtueMart Category Search

Автор ve1006

Ответов: 10
Просмотров: 7861
Последний ответ 18.01.2023, 10:39:10
от AzMandius
Как вывести модуль в страницу VirtueMart?

Автор harddrop

Ответов: 11
Просмотров: 4868
Последний ответ 13.11.2022, 13:11:37
от Evgen Kulibin
Как правильно настроить покупку в VirtueMart?

Автор varella

Ответов: 1
Просмотров: 2817
Последний ответ 12.10.2022, 16:14:04
от varella