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

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
Продажа купонов / кодов
« : 14.11.2019, 10:48:00 »
Всем кривет!

Встала задача продавать через сайт купоны, закрывающие цену разных услуг.
Но сделать надо как-то так, чтобы был 1 товар на 1 услугу (вместо 100 товаров с кодами на 1 услугу), а уникальный код бы тянулся откуда-то ещё.
Т.е имеем, например:

Посещение зала (10 раз) = 9000 рублей  (коды: A1xxx1, A1xxxx2, A1xxxx3)
Посещение зала (15 раз) = 13000 рублей (коды: A2xxxx1, A2xxxx2, A2xxxx3)

имеем 2 товара, но 6 кодов на продажу, коды - уникальные и хэшированные, но их генерацию можно в отдельную задачу вынести, не суть.

На вскидку видится отсылка уникального кода в письме после заказа, а сам код тянуть с отдельной таблицы кодов.

Может, кто из местных делал подобное или есть готовое решение (у разработчика нашел только продажу мест в театре/автобусе из похожего)?
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
Re: Продажа купонов / кодов
« Ответ #1 : 14.11.2019, 12:02:05 »
Лучше, конечно, в отдельной таблице хранить эти коды с привязкой к товару. Особенно если необходим поиск по этому коду (юзер ввел код - надо проверить существует ли и к какому товару относится).
Если поиск не нужен (товар известен - только проверить существование введенного кода для него), то можно все коды товара хранить в одном поле товара json-ом.
Ну а если хочется поизвращаться, чтоб и поиск был, и таблицы в БД не создавать, то можно хранить коды в виде файлов, с именем, совпадающим с кодом. Внутри файла укать ИД товара и другие данные, если нужны. Тогда искать можно файловым поиском и в БД никаких изменений делать не надо.
Но может что и получше предложат.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Продажа купонов / кодов
« Ответ #2 : 14.11.2019, 12:05:12 »
На вскидку видится отсылка уникального кода в письме после заказа, а сам код тянуть с отдельной таблицы кодов.
ну да, что то типа такого и нужно наверное. и при покупке в таблицу купонов писать id заказа например, чтоб связать купон с заказом и заодно пометить его как выданный
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Нет купонов в разделе "Опции"

Автор Mick_20

Ответов: 7
Просмотров: 819
Последний ответ 25.09.2021, 17:51:24
от Mick_20
Продажа электронных билетов

Автор BIGFOOT

Ответов: 3
Просмотров: 1054
Последний ответ 07.02.2018, 06:39:22
от kit2m2
Продажа весового продукта и начисление балов за покупки

Автор vova630

Ответов: 3
Просмотров: 987
Последний ответ 18.05.2017, 00:43:06
от vova630
Продажа без НДС

Автор FIORD_CMS

Ответов: 6
Просмотров: 1936
Последний ответ 07.03.2013, 14:53:59
от nevigen