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

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Есть список данных и есть кнопка на тулбаре "Удалить выбранное"...
Подскажите, как удалить только те записи, что отмечены в списке чекбоксами?
*

Kasumi

  • Захожу иногда
  • 70
  • 4 / 0
Вы хотите удалить данные из Joomla и бд? Достаточно удалить их из Joomla, из бд они так же удалятся
Или вы хотите удалить данные непосредственно из бд? Тогда выделите необходимые таблицы и нажмите "удалить выбранное". Если сомневаетесь, то можете прежде сделать резервную копию бд (вкладка экспорт, и сохранить в файл...)
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Получить все Id записей:

Код: php
$cIds = JRequest::getVar('cid', array(0), '', 'array');

Далее проходим по массиву и удаляем:

Код: php
foreach ($cIds as $id) {
//здесь удаляем запись $id
}
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Вы хотите удалить данные из Joomla и бд? Достаточно удалить их из Joomla, из бд они так же удалятся
Или вы хотите удалить данные непосредственно из бд? Тогда выделите необходимые таблицы и нажмите "удалить выбранное". Если сомневаетесь, то можете прежде сделать резервную копию бд (вкладка экспорт, и сохранить в файл...)
Я вероятно выразил свой вопрос не достаточно понятно...
Написал свой компонент, в админке которого выводится список с данными о поступивших заказах. Первая колонка списка содержит чекбоксы. На тулбаре компонента разместил кнопку "Удалить выбранное"... Некоторые заказы необходимо удалять, т.е. по идее нужно отметить строки, которые требуется удалить. Нажатие обозначенной кнопки должно вызывать задачу (...&task=delete), которая и выполнит удаление выбранных строк... Как составить запрос, чтобы удалить только отмеченные записи?
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Вообщем вот ссылка на статью в моем блоге, где как раз это расписывется.
Пока не получается... а выдаёт ошибку. Блог интересный - ставлю в закладки и буду читать. Спасибо!
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Цитировать
Блог интересный - ставлю в закладки и буду читать. Спасибо!
Только там по 1.5, но на 1.6/1.7 работать.

Какую ошибку выдает? Если не сложно, то выложите код контроллера и модели. Только закройте тэгом [spoiler.] [/.spoler], чтобы код на всю страницу не был.
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Код
Fatal error: Call to undefined method TableOrderonline::getErrorMsg() in /administrator/components/com_orderonline/models/orderonline.php on line 73

Спойлер
[свернуть]
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Ругается на $table->getErrorMsg(). Значит Вы программите под 1.7, а в ней уже нет такого метода в классе JTable. Попробуйте его просто поменять на $this->setError('Error during record delete');
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Поменял. Теперь сообщает:
Код
CGCA ADMIN DELETE FAILED[Error during record delete]
...и не удаляет.
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Поменял. Теперь сообщает:
Код
CGCA ADMIN DELETE FAILED[Error during record delete]
...и не удаляет.
А у Вас вообще создан класс таблицы? Просто в моем примере использовался JTable класс. Если нет, то пробуйте удалять используя JDatabase:

Код: php
public function remove()
{
$cids = JRequest::getVar('cid', array(0), 'post', 'array');

foreach ($cids as $cid) {
$this->_db->setQuery( 'DELETE FROM `#__robo_order` WHERE id  = ' . $this->_db->quote($cid) );

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

return true;
}

Естественно замените в запросе setQuery на свои данные.
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Класс таблицы:
Код
<?php
// No direct access
defined('_JEXEC') or die('Доступ ограничен!');

class TableOrderonline extends JTable
{
    var $id = null;

    function TableOrderonline($db) {
        parent::__construct('#__robo_order', 'oid', $db);
    }
}
?>

Пробовал указанный Вами вариант - говорит всё окей, но записи по прежнему не удаляет.
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
как можно вывести значение $cid в процессе удаления?.. может оно не совпадает со значением поля oid из БД.
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
А так?
Код
$this->_db->setQuery( 'DELETE FROM `#__robo_order` WHERE oid  = ' . $this->_db->quote($cid) );

var_dump($cid); exit();

И ещё $cids проверьте.
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
var_dump($cid); exit();

Выдаёт: string(0) ""
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
вообще везде нулевые значения... вот сам шаблон:
Код
<?php
   defined('_JEXEC') or die('Restricted access');

JToolBarHelper::title(JText::_('Управление заказами'), 'generic.png');
JToolBarHelper::deleteList(JText::_('CGCA ARE YOU SURE'));

JHtml::_('behavior.tooltip');
JHtml::_('behavior.multiselect');

?>
<form action="index.php?option=com_orderonline&view=orderonline" method="post" name="adminForm" id="adminForm">
<table class="adminlist">
<thead>
    <tr>
            <th><input type="checkbox" name="checkall-toggle" value="" onclick="Joomla.checkAll(this);" /></th>
<th width="5"><?php echo JText::_( 'ID' ); ?></th>
<th><?php echo JText::_( 'Дата' ); ?></th>
<th><?php echo JText::_( 'ФИО' ); ?></th>

    <th>MAIL</th>
    <th>URL</th>
    <th>Название сайта</th>
    <th>Краткое описание</th>
    <th>Ключевые слова</th>
    <th>Комментарий к заказу</th>
    <th>Услуга</th>
    <th>Статус оплаты</th>
    </tr>
    </thead>
<tfoot>
  <tr>
    <td colspan="12"><?php echo $this->pagination->getListFooter(); ?></td>
  </tr>
</tfoot>
<tbody>
<?php
$k = 0;
for ($i=0, $n=count( $this->items ); $i < $n; $i++)
{
$row = $this->items[$i];
$checked = JHTML::_('grid.id', $i, $row->id );
?>
<tr class="<?php echo "row$k"; ?>">
    <td><?php echo $checked; ?></td>
        <td><?php echo $row->oid; ?></td>
        <td><?php echo $row->date; ?></td>
        <td><?php echo $row->username; ?></td>
        <td><?php echo $row->mail; ?></td>
        <td><?php echo $row->siteaddr; ?></td>
        <td><?php echo $row->sitename; ?></td>
        <td><?php echo $row->descr; ?></td>
        <td><?php echo $row->keywords; ?></td>
        <td><?php echo $row->comments; ?></td>
        <td><?php echo $row->sid; ?></td>
        <td><?php echo $row->paystate; ?></td>
</tr>
<?php
$k = 1 - $k;
}
?>
</tbody>
</table>
<input type="hidden" name="option" value="com_orderonline" />
<input type="hidden" name="task" value="" />
<input type="hidden" name="boxchecked" value="0" />
<input type="hidden" name="controller" value="orderonline" />
<input type="hidden" name="view" value="orderonline" />
<?php
//Это что то вроде провержи на разбиение страницы.
echo JHTML::_( 'form.token' ); ?>
</form>
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
блин, ошибка была... вместо
Код
$checked = JHTML::_('grid.id', $i, $row->oid );
было:
Код
$checked = JHTML::_('grid.id', $i, $row->id );
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
По видимому $row->id надо заменить на $row->oid

UPDATE:
Вы меня опередили :) Тогда можно использовать и JTable метод ;)
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Иногда слона не заметишь :), первый опыт трудный самый...
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Иногда слона не заметишь :), первый опыт трудный самый...
Это точно. Сам в свое время намучался, да и сейчас  иногда бывают такие затыки ;)  crazy!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Состояние записи - как заставить работать во фронте?

Автор Thomas2000

Ответов: 7
Просмотров: 1249
Последний ответ 26.01.2015, 22:24:06
от b2z
Вывод предыдущей и следующей записи из БД (where?)

Автор ninth

Ответов: 20
Просмотров: 2044
Последний ответ 02.09.2014, 23:54:33
от ninth
Как удалить запись в бд?

Автор x_files_1

Ответов: 1
Просмотров: 1322
Последний ответ 25.06.2014, 21:03:24
от Aleks.Denezh
JInputCookie - возвращение результата записи куков

Автор yunoshev

Ответов: 7
Просмотров: 2203
Последний ответ 29.10.2013, 01:00:54
от Aleks.Denezh