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

pvi1

  • Давно я тут
  • 566
  • 16 / 2
Всем привет! Бьюсь над проблемой и не получается. Необходимо массово в товарах с категорией с id=1 создать атрибут с attr_id=1 с опциями:
attr_value_id=1, price_mod= + , addprice=1
attr_value_id=2, price_mod= + , addprice=10

Кто подскажет?
*

Linfuby

  • Завсегдатай
  • 1242
  • 176 / 0
  • Всё просто...
Импорт, или прямой запрос в БД.

А что именно не получается? И как не получается?
Немного воображения и логики, и любая проблема становится решенной.
Кривые решения - дают кривой результат!
Решения для JoomShopping
Благодарности и поддержка принимаются по след. реквизитам:
Яндекс.Деньги - 41001751720054
*

pvi1

  • Давно я тут
  • 566
  • 16 / 2
Импорт, или прямой запрос в БД.

А что именно не получается? И как не получается?
Запрос в БД. Конечно, можно так
Код
INSERT INTO `xxx_jshopping_products_attr2`(`product_id`, `attr_id`, `attr_value_id`,`addprice`) VALUES ('1','1','1','1');
INSERT INTO `xxx_jshopping_products_attr2`(`product_id`, `attr_id`, `attr_value_id`,`addprice`) VALUES ('1','1','2','10');
INSERT INTO `xxx_jshopping_products_attr2`(`product_id`, `attr_id`, `attr_value_id`,`addprice`) VALUES ('2','1','1','1');
INSERT INTO `xxx_jshopping_products_attr2`(`product_id`, `attr_id`, `attr_value_id`,`addprice`) VALUES ('2','1','2','10');
и так далее...

Но так как товаров очень много в категории, хочу пристегнуть как-то id категории, чтобы не писать кучу строк
Попытался так, но не катит
Код
INSERT INTO `xxx_jshopping_products_attr2`( `attr_id`, `attr_value_id`,`addprice`) VALUES ('1','1','1') WHERE product_id IN(SELECT product_id FROM xxx_jshopping_products_to_categories WHERE category_id=1);
INSERT INTO `xxx_jshopping_products_attr2`( `attr_id`, `attr_value_id`,`addprice`) VALUES ('1','2','10') WHERE product_id IN(SELECT product_id FROM xxx_jshopping_products_to_categories WHERE category_id=1);
« Последнее редактирование: 21.05.2017, 05:00:44 от pvi1 »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вывести описание атрибута

Автор Napst3r

Ответов: 2
Просмотров: 1383
Последний ответ 31.07.2024, 12:24:00
от Napst3r
Вывод характеристик товара в списке товаров (категории)

Автор voland

Ответов: 4
Просмотров: 3984
Последний ответ 17.09.2022, 13:21:03
от victorantoniak
Вывод названия атрибута за место Выберите

Автор djwolf

Ответов: 9
Просмотров: 3510
Последний ответ 14.01.2022, 23:06:27
от Akeksandr
Отображение Атрибута в категориях (Решено)

Автор darkghost

Ответов: 1
Просмотров: 2714
Последний ответ 01.10.2021, 17:30:36
от darkghost
Отображение цены товара в категории

Автор Kadimp

Ответов: 1
Просмотров: 2655
Последний ответ 28.09.2021, 06:55:36
от nevigen