Новости 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 Гость просматривают эту тему.
  • 0 Ответов
  • 4569 Просмотров
*

smivan85

  • Осваиваюсь на форуме
  • 47
  • 3 / 0
В Seblod3 создан материал. Необходимо дать пользователю открыть его для правки, поправить некоторые поля и сохранить в отдельный материал.
Возможно, этот вопрос касается больше jooml-ы. Дело в том, что в форму можно вывести Article Alias и Article ID (и не только), и при сохранении копии можно просто эти поля поправить, но работает это криво: В таблице  [db]_cck_store_form_[appfolder1] строчки новые создаются, а в [db]_content — нет.
Отсюда вопросы:
1. Какие поля из базы необходимо править, чтобы при нажатии кнопки sumbit правильно сохранялся новый материал?
2. Как автоматически править поля (проверка на уникальность штатными средствами seblod, затем присвоить, например, id по формуле id=id(max)+1)?
3. Скорее всего, есть иной путь, который мне по неопытности неведом. Буду рад наставлению.
Соответствующий вопрос задаю на сайте seblod. pro/forum/33-obshchie-voprosy/4561-zapolnenie-polej-v-forme-dannymi-iz-bazy

Спасибо и всех поздравляю с Победой в Великой Отечественной войне!
« Последнее редактирование: 08.05.2015, 10:29:16 от smivan85 »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Сохранение в БД

Автор ubo

Ответов: 0
Просмотров: 3695
Последний ответ 30.03.2015, 13:28:28
от ubo
Ссылка на категорию со страницы материала

Автор dnz

Ответов: 0
Просмотров: 1890
Последний ответ 01.04.2013, 14:45:11
от dnz
Удаление материала

Автор KKAAZZOO

Ответов: 2
Просмотров: 2099
Последний ответ 30.05.2012, 08:51:18
от KKAAZZOO
Дата публикации материала

Автор ProstoDushka

Ответов: 1
Просмотров: 1875
Последний ответ 15.02.2012, 23:32:54
от ProstoDushka
При редактировании через админку пропадает текст.

Автор griz

Ответов: 8
Просмотров: 3034
Последний ответ 12.04.2011, 22:49:08
от mohax