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

Информатор

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Возможно ли как то использовать языковой файл компонента /language/en-GB/... в админпанеле этого компонента (/administrator/components/...)?
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
Можно так:
Код: php
$lang = JFactory::getLanguage();
$lang->load('com_mycomp', JPATH_SITE);

Другое дело зачем из административной панели грузить языковой файл, предназначенный для сайта? На сайте эти переменные почти наверняка не нужны, поэтому лучше все-таки сделать 2 файла - для сайта и для административной панели. В итоге каждый их них получится меньше и будет быстрее загружаться и меньше памяти требовать.
*

Информатор

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
smart, спасибо, помогло.
Цитировать
Другое дело зачем из административной панели грузить языковой файл, предназначенный для сайта?
Заказной компонент. Основная функция компонента - высылать письмо с фронт-энда. Так же небходимо сделать "resend" из админки. Чтобы не приходилось дублировать переводы, наверно лучше вложить уже существующий из компонента.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Jroute компонента альбомов

Автор Koot

Ответов: 2
Просмотров: 987
Последний ответ 03.08.2019, 10:21:04
от Aleks.Denezh
Как использовать функции компонента в модуле?

Автор specialist-web

Ответов: 6
Просмотров: 1300
Последний ответ 12.05.2019, 12:26:10
от AlekVolsk
params->get для компонента, как получить свои собственные параметры для компонента

Автор klubnichkaaa

Ответов: 13
Просмотров: 14362
Последний ответ 01.06.2017, 20:20:28
от Septdir
Выбор пользователя в модальном окне в админке

Автор orexov_m

Ответов: 0
Просмотров: 1177
Последний ответ 11.04.2017, 11:35:43
от orexov_m
Плагин Smart Search для своего компонента

Автор ftp27

Ответов: 1
Просмотров: 2106
Последний ответ 07.01.2017, 19:44:04
от newvideo