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

DenVeR777

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
Иногда бывает необходимо поменять цены на все товары, на группы или категории товаров, чтобы запустить акцию.
Вроде все просто, фильтруем, выбираем нужные, нажимаем изменить, умножаем цены на 1-скидка, ставим "Использовать старое значение цены"... И все вроде бы классно, нам удалось сделать скидку на тысячу товаров! НО в атрибутах старая цена не поменялась  !
Когда товаров немного это не проблема, взяли поправили ручками(если помните старые цены) и все готово, а вот когда их несколько тысяч...*suicide*

Решение(актуально для JS 4.17.0):
в файле /administrator/components/com_jshopping/models/products.php в районе 943 строки находим следующий код:
Код
        if ($post['product_old_price']!=""){
                $price = saveAsPrice($post['product_old_price']);
                if ($post['mod_old_price']=='%')
                    $_adv_query[] = " `old_price`=`old_price` * '".$price."' / 100 ";
                elseif($post['mod_old_price']=='=')
                    $_adv_query[] = " `old_price`= '".$price."' ";
                else
                    $_adv_query[] = " `old_price`=`old_price` ".$post['mod_old_price']." '".$price."' ";
        }
меняем его на
Код
        if ($post['product_old_price']!=""){
            if ($post['use_old_val_price']!=1){
                $price = saveAsPrice($post['product_old_price']);
                if ($post['mod_old_price']=='%')
                    $_adv_query[] = " `old_price`=`old_price` * '".$price."' / 100 ";
                elseif($post['mod_old_price']=='=')
                    $_adv_query[] = " `old_price`= '".$price."' ";
                else
                    $_adv_query[] = " `old_price`=`old_price` ".$post['mod_old_price']." '".$price."' ";
            }
        }

Далее в этом же файле находим в районе 1015 строки:
Код
if ($post['use_old_val_price']==1){
   $product->set('product_old_price', $oldprice);
}
заменяем на
Код
if ($post['use_old_val_price']==1){
   $db = JFactory::getDBO();
   $product->set('product_old_price', $oldprice);
   $query = "update `#__jshopping_products_attr` SET `old_price`=`price` where product_id='".$db->escape($id)."'";
   $db->setQuery($query);
   $db->query();
}

Немного грязно, но работать будет - проверено  ;)

А теперь вопрос к знатокам:
Я не исключаю, что я туповат *ОХ-Х-Х* и просто не увидел какую-то галочку в интерфейсе. Пожалуйста сообщите об этом. А если нет, то куда написать? После обновления все эти хаки слетят к чертям(
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
просто не увидел какую-то галочку в интерфейсе
ее нет.

После обновления все эти хаки слетят к чертям
чтоб не слетели, нужно это сделать плагином. либо есть готовый https://nevigen.com/ru/addons/massovoe-izmenenie-tsen-dlya-atributov-tovarov-v-joomshopping.html
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

DenVeR777

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
Спасибо!
А я не смог ничего найти по проблеме, мне быстрее и дешевле было плагин купить, чем разбираться с кодом JS))
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
ну свою задачу то вы уже решили, вам уже по всей видимости он и не нужен :) но вообще плагин более универсальный, поскольку например старая цена для разных атрибутов может отличаться суммой, т.е. для одного атрибута это может быть +100 руб, а для другого +150, и т.п., а у вас всегда одна и та же разница добавляется. ну и как вы уже правильно заметили, хаки придется править при каждом обновлении...
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Стоимость доставки для нескольких товаров. Должна ли рассчитываться?

Автор goga_pgasovav

Ответов: 2
Просмотров: 902
Последний ответ 14.06.2025, 13:08:57
от victorantoniak
Не сохраняется порядок товаров в админке

Автор heartlink

Ответов: 7
Просмотров: 2024
Последний ответ 08.10.2024, 10:24:02
от kit2m2
Сортировка товаров внутри категории

Автор oslyabya

Ответов: 1
Просмотров: 1430
Последний ответ 02.08.2024, 22:06:39
от nevigen
Обновление количества товаров в корзине без кнопки "Обновить корзину"

Автор kit2m2

Ответов: 4
Просмотров: 2940
Последний ответ 23.07.2024, 12:23:33
от Шрек
Добавление одного файла в группу товаров

Автор DarkMare

Ответов: 1
Просмотров: 1281
Последний ответ 16.06.2023, 10:13:59
от kit2m2