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

jimjarmusch

  • Новичок
  • 1
  • 0 / 0
Есть такая задача, выводить все товары категории на одну страницу. Проблема в том, что если их много (скажем, больше 20) страница довольно долго загружается.
Хочу организовать отображение товаров таким образом, чтоб изначально загружалось, к примеру 10, а потом остальные по мере прокрутки самой страницы вниз.
В общем, чтоб было наподобие подгрузки сообщений в контакте или поиска по картинкам в Google.
Облазил форумы, но не нашел ничего кроме подобной штуки с постами в Wordpress. Хотелось бы что-то ближе к VM и Joomla.
Подскажите, куда двигаться.
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
достаточно нетривиальная штука, придется сильно много писать своего кода.
В гугле есть примеры, естественно, их можно использовать только как алгоритм
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

fsv

  • Живу я здесь
  • 2782
  • 411 / 2
гуглите Lazy Load, в VM без проблем.
Веб-разработка: заказ. Только новая разработка.
*

yo3o

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
увы но Lazy Load например как в ВК нереально найти!

пришлось делать свой...
*

moolkin

  • Захожу иногда
  • 65
  • 15 / 0
ну так поделитесь с сообществом?? )
 и все вам скажут спасибо
делаю и помогаю делать сайты на джумле.
кому интересно - стучитесь в мой профиль на фри-лансе
https://www.free-lance.ru/users/Moolkin/
или в аську/скайп
*

yo3o

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
с радостью поделюсь но при одном условие! дело в том что мой вариант срабатывает когда пользователь прокрутил всю страницу в низ! а это довольно убога...
и так мне нужна функция которая будет срабатывать когда объект становиться виден пользователю. а в замен я дам вам свой скрипт!
*

yo3o

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
и еще мой вариант не очень потому-что использует cURL для загрузки нужных данных
*

runyugin

  • Захожу иногда
  • 56
  • 0 / 0
Актуально... Есть у кого решение?
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вывод таблицы, деление на страницы

Автор March Cat

Ответов: 6
Просмотров: 1185
Последний ответ 09.01.2019, 18:49:15
от dmitry_stas
Меню схлопывается после перезагрузки страницы

Автор onelawyer

Ответов: 10
Просмотров: 1809
Последний ответ 11.10.2017, 14:50:48
от effrit
Как вставить модуль в код нужной страницы php?

Автор zvi

Ответов: 7
Просмотров: 3776
Последний ответ 12.04.2016, 19:36:55
от AlekVolsk
Модуль. Сообщение о включенном AdBlock. Как отпустить Javascript в низ страницы?

Автор cartgen

Ответов: 2
Просмотров: 1765
Последний ответ 19.08.2015, 23:42:16
от palexa
Не переключаются страницы после использования фильтров

Автор DimkaJack

Ответов: 41
Просмотров: 4064
Последний ответ 16.04.2014, 11:08:53
от b2z