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

whatyouname?

  • Осваиваюсь на форуме
  • 38
  • 0 / 0
Не сохраняет HTML теги в бд
« : 21.04.2011, 14:22:22 »
Здравствуйте, столкнулся с такой проблемой при написании компонента, если в стандартном поле ввода <input...> ввести  html-теги (например <a>), то в бд сохраняется просто пустой символ. Процедура сохранения стандартная.
Код
function store()
{
$row =& $this->getTable();

$data = JRequest::get( 'post' );

if (!$row->bind($data)) {
$this->setError($this->_db->getErrorMsg());
return false;
}

if (!$row->check()) {
$this->setError($this->_db->getErrorMsg());
return false;
}

if (!$row->store()) {
$this->setError( $row->getErrorMsg() );
return false;
}

return true;
}

Пробовал htmlspecialchars и ещё много чего - не помогает. В чём может быть проблема?
*

moskitos80

  • Осваиваюсь на форуме
  • 21
  • 3 / 0
Re: Не сохраняет HTML теги в бд
« Ответ #1 : 23.04.2011, 00:07:20 »
Ответ очень простой:
Код
JRequest::get( 'post' )
- отфильтроввывает HTML теги.

Вам нужно сделать так:
В свойство объекта класса, расширяющего JTable, в которое вы хотите сохранить текст с HTML - персонально передайте данные из запроса таким образом:
Код
$row->content = JRequest::getVar('content','','post','string',JREQUEST_ALLOWRAW);
*

whatyouname?

  • Осваиваюсь на форуме
  • 38
  • 0 / 0
Re: Не сохраняет HTML теги в бд
« Ответ #2 : 24.04.2011, 16:39:10 »
Спасибо за ответ. Сделал так, как вы написали, напрямую присвоил свойству расширяющего класса переменную из запроса, но всё равно не сохраняет.
Что ещё более интересно, он почему-то в принципе не даёт записывать в свойства
Код
$row->content = 'example';
тоже не сохраняет.

Я так подумал, может свойства класса JTable не являются публичными, и дописал в свой расширяющий класс метод
Код
public function setContent($a) {
$this->content = $a;
}
А уже из функции store модели компонента вызвал
Код
$row->setContent('example');
И всё равно ничего...
Может есть какие-нибудь мысли по этому поводу? Заранее спасибо.
*

moskitos80

  • Осваиваюсь на форуме
  • 21
  • 3 / 0
Re: Не сохраняет HTML теги в бд
« Ответ #3 : 24.04.2011, 22:49:58 »
К свойствам класса - наследника JTable можно обращаться напрямую, если вЫ их определите как публичные (это обычно личное предпочтение разработчика) и тут методы аксессоры не понадобятся, а так советую проверить, возможно у вас банально опечатка и имя поля в базе данных не совпадает с именем свойства JTable. Однажды у меня была подобная ситуация - не сохранялись данные. Я тупо забыл объявить одно из свойств в классе потомке JTable. И данные предназначенные для одного из полей БД улетали в никуда. А метод check() - если не перегружен в вашем классе (вообще по своей сути абстрактен, и тупо возвращает true) ни каких гарантий сопоставимости данных и полей вам не даст. Просмотрите ещё раз ваш код и названия полей в БД. Проверьте также на всякий случай, является ли объект с которым вы работаете действительно тем, за что вы его принимаете (print_r())... к примеру, но это уже тонкости отладки и они должны быть вам знакомы. :)
*

whatyouname?

  • Осваиваюсь на форуме
  • 38
  • 0 / 0
Re: Не сохраняет HTML теги в бд
« Ответ #4 : 30.04.2011, 14:23:58 »
В том-то и дело, что всё перепроверено, если в поле вбить число или слово - то всё в базе сохраняет и выводит, а если теги - тупо режет. А насчёт объекта, то точно тот, все другие поля передаются, прямо мистика какая-то...
« Последнее редактирование: 30.04.2011, 15:03:06 от whatyouname? »
*

whatyouname?

  • Осваиваюсь на форуме
  • 38
  • 0 / 0
Re: Не сохраняет HTML теги в бд
« Ответ #5 : 30.04.2011, 15:02:14 »
Наконец-то разобрался! Полезно бывает на время отвлечься ^-^
Когда стал смотреть функцию store, заметил, что нужно было вместо
Код
$row->content = JRequest::getVar('content','','post','string',JREQUEST_ALLOWRAW);
написать
Код
$data['content'] = JRequest::getVar('content','','post','string',JREQUEST_ALLOWRAW);
естественно после
Код
$data = JRequest::get( 'post' );
Потому что впоследствии он "биндит" именно этот массив
Код
$row->bind($data)
После этого всё заработало.

Спасибо moskitos80 за помощь.
*

moskitos80

  • Осваиваюсь на форуме
  • 21
  • 3 / 0
Re: Не сохраняет HTML теги в бд
« Ответ #6 : 01.05.2011, 04:00:34 »
Всегда пожалуйста, рад что помог, но у вас всё равно как то мудрёно получается. Вот посмотрите мой пример метода, которому нужно сохранить текст с html-форматированием:

Код
  public function savenewevent()
  {
    JRequest::checkToken() or jexit( 'Invalid Token' );
   
    JTable::addIncludePath(JPATH_COMPONENT_ADMINISTRATOR.'/tables/');
    $tableEvent = JTable::getInstance('All','Table');
   
    // Здесь привязываем:
    if(!$tableEvent->bind(JRequest::get('post')))
    {
      $this->setRedirect(JRoute::_('index.php?option=com_calendar&task=add_event'),'ОШИБКА: Не удалось обработать данные.');
    }

    // Вот здесь и назначаем!
    $tableEvent->content = JRequest::getVar('content','','default','string',JREQUEST_ALLOWRAW);
   
    // А здесь сохраняем...
    if(!$tableEvent->store())
    {
      $this->setRedirect(JRoute::_('index.php?option=com_calendar&task=add_event'),'ОШИБКА: Не удалось сохранить данные.');
    }
   
    $this->setRedirect(JRoute::_('index.php?option=com_calendar&task=add_event'),'Спасибо. Ваше событие добавлено и после проверки администрацией появится на сайте.');
  }

И никаких лишних массивов.  ^-^
*

whatyouname?

  • Осваиваюсь на форуме
  • 38
  • 0 / 0
Re: Не сохраняет HTML теги в бд
« Ответ #7 : 01.05.2011, 16:56:43 »
Ну да, можно и так  ^-^
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Нужно доработать модуль html-код

Автор fbr

Ответов: 45
Просмотров: 3572
Последний ответ 30.09.2014, 00:37:34
от Aleks.Denezh
HTML в модальном окне в админке

Автор Grigory S.

Ответов: 5
Просмотров: 1666
Последний ответ 03.07.2014, 16:01:02
от zomby6888
[Решено] Не сохраняются HTML тэги в самописном компоненте

Автор evgen777

Ответов: 5
Просмотров: 1314
Последний ответ 04.03.2014, 15:40:47
от evgen777
Как форму HTML с обработчиком на php превравить в модуль Joomla 3.1.5?

Автор sevzem

Ответов: 4
Просмотров: 1477
Последний ответ 14.02.2014, 18:25:10
от sevzem
[Решено] Использование нескольких геттеров одной модели несколькими view.html.php Joomla 3

Автор adamatis

Ответов: 5
Просмотров: 2615
Последний ответ 14.08.2013, 14:44:16
от adamatis