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

Dorfman

  • Завсегдатай
  • 1202
  • 78 / 4
  • Почти влез...
Аренда биллбордов
« : 16.08.2019, 10:24:55 »
Всем привет!

Встал вопрос о реализации аренды рекламных конструкций (биллбордов и пр.). Не просто каталог, а именно с функцией заказа, бронирования, резервирования и т.д...

Что-то мне подсказывает, что это можно реализовать на основе компонентов бронирования отелей, но я никогда не сталкивался с этим.

ПыСы На фронте хотелось бы видеть таблицу с полями:
* Артикул
* Район
* Описание
* Статус (свободно, занято, в резерве)
* Миниатюра фотографии
* Чекбокс «заказать», если свободно

На карточке объекта:
Всё то же самое плюс карта и дата окончания срока аренды (если занято) или дата окончания бронирования (резервирования)

Кто подскажет, куда копать?

ПыПыСы
Понимаю, что это можно сделать на Эмеральде или другой ССК, но реально нет времени для освоения данных Монстров
« Последнее редактирование: 16.08.2019, 10:32:05 от Dorfman »
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
Re: Аренда биллбордов
« Ответ #1 : 16.08.2019, 10:42:17 »
Как я понимаю "опталы онлайн" не будет.
Тогда хватит com_content + штатные доп поля + content card от jl или radicalform для заказа.

Ну и конечно чуть под шаманить это дело.
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
*

Dorfman

  • Завсегдатай
  • 1202
  • 78 / 4
  • Почти влез...
Re: Аренда биллбордов
« Ответ #2 : 16.08.2019, 11:05:10 »
К сожалению, механизм добавления срока аренды или бронирования вручную не айс. Кроме того, уж совсем не хочется отслеживать вручную срок окончания бронирования. Так что вряд ли это вариант решения. Но всё равно спасибо. Есть другие варианты?
*

Webster

  • Захожу иногда
  • 185
  • 7 / 0
Re: Аренда биллбордов
« Ответ #3 : 16.08.2019, 11:15:35 »
Что-то мне подсказывает, что это можно реализовать на основе компонентов бронирования отелей, но я никогда не сталкивался с этим.
Тут действительно лучше не придумать
ибо статусы сами будут меняться и не надо каждый раз лезть
*

Dorfman

  • Завсегдатай
  • 1202
  • 78 / 4
  • Почти влез...
Re: Аренда биллбордов
« Ответ #4 : 16.08.2019, 11:58:12 »
Извините за вопрос, а каким образом они будут сами меняться? Где об этом почитать?
*

Webster

  • Захожу иногда
  • 185
  • 7 / 0
Re: Аренда биллбордов
« Ответ #5 : 16.08.2019, 12:07:44 »
Извините за вопрос, а каким образом они будут сами меняться? Где об этом почитать?
все зависит от того какой компонет использовать
в solidress допустим статусы меняются
а так по логике все просто (на примере номера в отеле разберем):
если номер свободен, то его можно забронировать
если занят то или не выводится вовсе или выводится, но показано что занято до такого то числа(зависит от настроек)
при резервировании свободного, до подтверждения админом (письмо с заявкой прилетает как надо) - номер висит в статусе резервирования и его так же нельзя забронировать
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
Re: Аренда биллбордов
« Ответ #6 : 16.08.2019, 13:17:36 »
К сожалению, механизм добавления срока аренды или бронирования вручную не айс. Кроме того, уж совсем не хочется отслеживать вручную срок окончания бронирования. Так что вряд ли это вариант решения. Но всё равно спасибо. Есть другие варианты?
Это все можно и на доп полях сделать. плагин плагины и еще раз плагины
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
*

Dorfman

  • Завсегдатай
  • 1202
  • 78 / 4
  • Почти влез...
Re: Аренда биллбордов
« Ответ #7 : 02.11.2019, 17:38:19 »
Это все можно и на доп полях сделать. плагин плагины и еще раз плагины
Можете назвать пример плагина для ком_контента, который поменяет статус при достижении определённой даты? Как вообще плагин может влиять на состояние данных в БД?
*

Viclingvolive

  • Осваиваюсь на форуме
  • 31
  • 2 / 1
Re: Аренда биллбордов
« Ответ #8 : 03.11.2019, 21:23:28 »
Цитировать
Как вообще плагин может влиять на состояние данных в БД?
Доброе время суток Всем!
Как я думаю это можно сделать - либо кроном что в принципе верно либо из админ панели или фронта как то системным плагином )))
В общем крон!!
Всем Удачи!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться