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

x_files_1

  • Осваиваюсь на форуме
  • 31
  • 0 / 0
Как удалить запись в бд?
« : 25.06.2014, 18:23:15 »
Вопрос такой:
Есть в панели админиматратора моего компонента 2 раздела = оба управляют разными таблицами
Суть в том что мне надо из одного вьюва первой таблицы удалить запись из второй таблицы
Просто запрос на удаление sql не подойдет
Мне надо именно вызвать цепочку действий при стандартном удалении при нажатии на "Удалить"

В планах в первом вьюве сделать кнопку на удаление данных из другого вьюва

Конечно запутанно объяснил)))
*

Aleks.Denezh

  • Живу я здесь
  • 3401
  • 428 / 4
Re: Как удалить запись в бд?
« Ответ #1 : 25.06.2014, 21:03:24 »
Если вы делали по стандартам Joomla компонент то:
Переопределяете в модели которая у вас наследуется от JModelAdmin метод public function delete(&$pks) (тоесть банально из класса JModelAdmin  копируете весь этот метод в свой класс)

После строк:
Код: php
if (!$table->delete($pk))
{
$this->setError($table->getError());
return false;
}
Вставляете нужный вам код! $pk - это ID записи которая удаляется в текущий момент!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

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

Автор maxis

Ответов: 34
Просмотров: 3137
Последний ответ 27.01.2015, 08:23:51
от maxis
При регистрации нового пользователя - добавить еще одну запись

Автор rafaello9

Ответов: 29
Просмотров: 4665
Последний ответ 20.06.2013, 23:06:02
от Fedor Vlasenko
Как удалить выбраннные записи из БД?

Автор At3iSt

Ответов: 19
Просмотров: 4429
Последний ответ 13.10.2011, 18:51:45
от b2z