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

Asttoxa

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Доброе утро друзья!

В Joomla существуют два вида отображения категорий в меню:
1) Как блог категории (в которой отображаются материалы этой категории в виде блога)
2) Как список материалов категории. (тут понятно)

Так вот потребовалось сделать нечто свое. А конкретнее нужно сделать третий вид, что то вроде своего поля с текстом (а лучше конечно с кодом). Тоесть чтобы не отображались ни список ни блог, а свои переходы на материалы в этой категории. Подскажите где копать?
Я конечно могу залезть в нутрянку и PHP поставить условие и отключить или включить список или блог и вставить свое, но это как бы ломает всю красоту CMS. Хотелось бы покрасивще сделать :) Или может есть другие способы о которых я не знаю.

Конечно встанет вопрос почему я не могу отобразить в меню ОТДЕЛЬНЫЙ МАТЕРИАЛ в котором творить что заблагорассудится. Это конечно можно сделать. Но давайте представим следующую ситуацию:

У нас есть категория "НУЖНАЯ КАТЕГОРИЯ" если мы ее назначим на кнопку меню то будет путь выглядеть так:
"HOME" - "НУЖНАЯ КАТЕГОРИЯ" 
Если мы зайдем в материал в этой категории путь будет выглядеть так:
"HOME" - "НУЖНАЯ КАТЕГОРИЯ" - "КАКОЙ ТО МАТЕРИАЛ"

Если я сделаю в материале ссылки на список определенных материалов и включу этот материал в меню то ситуация изменится, а именно если мы находимся например на HOME и нажав эту кнопку мы перемещаемся вот сюда "HOME" - "КАТЕГОРИЯ МАТЕРИАЛА В КНОПКЕ" - "МАТЕРИАЛ В КНОПКЕ" ..... Тоесть нажав пользователь в хлебных крошках на "КАТЕГОРИЯ МАТЕРИАЛА В КНОПКЕ" он попадет хрен знает куда не связанным с "НУЖНОЙ КАТЕГОРИЕЙ" и "КАКИМ ТО МАТЕРИАЛОМ"
Воть. Чет мне кажется запутанно как то изложил. Но лучше поправить это ответами на наводящие вопросы :)

Спасибо за внимание. :)
*

Aleks.Denezh

  • Живу я здесь
  • 3401
  • 428 / 4
А вариантов куча..
1. Написать свой компонент
2. Выбрать альтернативный макет для блога категорий, и написать этот макет
3. Добавить свою модель, вид в com_content..
*

Asttoxa

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Я к сожалению не знаком со всеми тремя способами. А можно немножко поподробнее о них. Или может ткнете носом в грамотные ссылочки. Спасибо.

ЗЫ Глянул что такое компонент. Это чтото такое крупное колоссальное. Мне кажется писать компонент для такой простой вещи через чур.

По поводу альтернативных вот тут для Joomla 3 аналогично?

« Последнее редактирование: 20.11.2013, 14:00:13 от Asttoxa »
*

Asttoxa

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Все подробненька нашел вот ТУТ
Может кому пригодится. Всем спасибо.
ЗЫ Главное спасибо Istaan. Натолкнул на путь истинный!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как добавить много меток сразу?

Автор Sergeyy

Ответов: 1
Просмотров: 1121
Последний ответ 10.12.2018, 16:49:03
от Sergeyy
Добавить проверку в форму регистрации

Автор apsorry

Ответов: 3
Просмотров: 1436
Последний ответ 08.01.2016, 15:40:02
от apsorry
Как в модели ограничить количество выводимых материалов для каждой категории?

Автор fbr

Ответов: 12
Просмотров: 1871
Последний ответ 05.09.2015, 23:43:47
от robert
Добавить класс каждому li

Автор xenos

Ответов: 6
Просмотров: 1751
Последний ответ 15.04.2015, 09:14:47
от xenos
Добавить в модуль возможность добавлять и удалять его параметры

Автор Arpeccop

Ответов: 14
Просмотров: 1946
Последний ответ 23.10.2014, 16:23:48
от AlterEgo