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

TyronNIKO

  • Осваиваюсь на форуме
  • 19
  • 0 / 0
Добрый вечер!
 В Joomla я новичек, и пока только разбираюсь. Потихоньку админю сайт, добавляю в него модули, контент.
 Столкнулся с такой проблемой: верстаю CSS, меняю дизайн модуля, но не могу понять откуда ему присваивают класс. В коде не вижу (с Джавой не дружу), но беглый просмотр не имеет намеков на названия нужных классов.
 Может я попросту не там ищу?

PS. Смотрел в самом модуле. Судя по всему классы исходят от шаблона.

Может посоветуете где посмотреть?
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
Re: Присваивание классов блокам
« Ответ #1 : 14.11.2016, 19:20:49 »
добрый.
у модуля есть поле "суфикс класса модуля".
впишите туда что-нибудь (можно с пробелом в начале) и привяжите к получившемуся классу свои стили
*

TyronNIKO

  • Осваиваюсь на форуме
  • 19
  • 0 / 0
Re: Присваивание классов блокам
« Ответ #2 : 14.11.2016, 19:31:12 »
Да, с этим я разобрался. У модуля есть свой ID. Я к нему и привязался.
Но, в самом модуле есть разные поля (форма поиска), у одного поля почему то есть класс, а у другого нету... Вот тут и стоит задача, присвоить этому полю класс. Можно конечно просто использовать наследие классов, но хочеться понять, так скажем "механику" этого действия.
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
Re: Присваивание классов блокам
« Ответ #3 : 14.11.2016, 19:50:12 »
механика простая - набор полей задает разработчик.
обычно из добавляют (смотрите в папках с модулем XML файл, там они описаны)
но если их нет - делаете наследование от родителя или дописывайте сами поля (но при обновлении придется повторять действия)
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как присвоить класс блокам через JS?

Автор onniby

Ответов: 2
Просмотров: 805
Последний ответ 01.06.2022, 04:25:11
от beliyadm
Дубль классов в модуле

Автор Влад

Ответов: 5
Просмотров: 888
Последний ответ 02.11.2016, 18:47:10
от fbr