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

Алишер

  • Захожу иногда
  • 203
  • 2 / 1
  • Хочешь мира, готовься к войне!
Скажите пожалуйста!
Как на отдельных страницах категории сделать фон разным? Возможно ли это?
Шаблон Протостар!
*

maggor

  • Новичок
  • 8
  • 0 / 0
На примере одного сайта:

/*Все остальные страницы*/
.all {
background-image: url("../image/background-image.jpg");
background-attachment: fixed;
background-position: center top;
background-repeat: no-repeat;
}
/*Категория "Ноутбуки"*/
.notebooks {
background-image: url("../image/cb/bg1.jpg");
background-attachment: fixed;
background-position: center top;
background-repeat: no-repeat;
}
*

stendapuss

  • Давно я тут
  • 945
  • 20 / 0
  • Valera Stankevich
Шаблон копируете, архивируете, устанавливаете. Предварительно во всех файлах меняете название. Допустим был Протостар, меняете Протостар2 (или как нравиться, лучше указать страницу). Проще будет разбираться потом, если шаблонов много будет. По английски название пишем. Ставите для определенных страниц. Для них меняете фон и что надо.
Лучше не в менеджере шаблонов делать копию, а как писал выше. Если в менеджере шаблонов делать начинают мозг парить.
« Последнее редактирование: 01.03.2015, 10:53:57 от stendapuss »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Отображение заголовков материалов в категориях в шаблоне JoomShaper Helix 3

Автор Kstein

Ответов: 1
Просмотров: 824
Последний ответ 13.02.2020, 14:02:34
от Kstein
Шаблоны jm-education, jm-services. Не могу поменять фон

Автор MagomedM

Ответов: 4
Просмотров: 997
Последний ответ 15.12.2019, 22:58:02
от AlexB
gk instyle -как поменять лого

Автор Ob4578

Ответов: 3
Просмотров: 1008
Последний ответ 21.06.2018, 07:30:33
от lexxbry
Поменять местами позиции в шаблоне YOOtheme

Автор Pikteel

Ответов: 2
Просмотров: 1210
Последний ответ 28.04.2018, 20:25:50
от Bozhkov2
Yootheme PRO нет кастомизации шаблона для отдельных страниц

Автор Mark Zuckerberg

Ответов: 0
Просмотров: 989
Последний ответ 17.04.2018, 12:07:20
от Mark Zuckerberg