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

romagromov

  • Давно я тут
  • 692
  • 9 / 3
Обычная сортировка?
« : 07.05.2012, 13:20:35 »
Чтобы не лезть куда-то очень глубоко:
Вообще ничего не трогал
Тип контента стандартный - статьи.
Добавил маленькую форму добавления новых статей.
Добавил 5 статей.
После, добавил List & Searce Form - самую простую, с несколькими полями.
Получил такое:



То есть, сортировкой не пахнет, хотя для сортировки поля на закладке Order добавлены.

И еще, в списке нет ни одной ссылки, как зайти в материал непонятно.
*

Posokhoff

  • Осваиваюсь на форуме
  • 39
  • 5 / 0
  • www.seblod.pro
Re: Обычная сортировка?
« Ответ #1 : 30.05.2012, 03:01:46 »
1) установили ли вы в закладке List линки на контент материала? (нажать "2", выбрать Link->Content).
2) В Order помимо простого добавления поля, какие параметры установили - Ascending или Descending?
Кроме сортировки непосредственно в типе поиска, задать ее параметры можно также в настройках пункта меню с вашим типом поиска в Basic Options ( CCK )->Default Order. Причем выбор сортировок здесь более широкий.
3) Если Unpublished материалы не нужны, добавьте поле Article State с live значением "1" в поиск
*

romagromov

  • Давно я тут
  • 692
  • 9 / 3
Re: Обычная сортировка?
« Ответ #2 : 01.09.2013, 23:53:12 »
Здравствуйте.
Извините, что так долго молчал ))

В общем, прослушал ваш урок, и в процессе повторял действия. Почти все получилось, но споткнулся опять на сортировке...

Не сортирует, хоть ты тресни...




В настройках пункта меню все поставил



В настройках самих полей тоже



Однако, установить тип поля integer - int(11) не удается, оно просто не сохраняется (отдельный топик) http://joomlaforum.ru/index.php/topic,274541.0.html


Потом, над материалами, есть поля поиска. Ну выбрал я цвет, дальше что делать? Нет кнопки никакой типа "Искать"... Автоматические тоже не фильтрует...

И еще, я не понял, зачем вы создаете поле "Title phone", а затем плагином SD Field Concat (который кстати 15 евро стоит) передаете в него название модели...
Разме нельзя сразу создать в поле "Модель телефона" указать куда сохранять - в поле title (название материала joomla).

Спасибо.
« Последнее редактирование: 01.09.2013, 23:59:43 от romagromov »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться