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

aldem67

  • Осваиваюсь на форуме
  • 12
  • 1 / 0
Подключение таблицы в J1.7
« : 01.10.2011, 17:05:37 »
Подскажите, пожалуйста. Переделываю свой компонент с j1.5 на j1.7

но вот тут
Код: php
$row=JTable::getInstance('Blogsection','Table');
$cid=JRequest::getVar('cid',array(0),'','array');
$id=intval($cid[0]);
if($id>0){
$row->load($id);
}
$this->assignRef('row',$row);

в первой строке выскакивает предупреждение
Код: html4strict
Warning: Invalid argument supplied for foreach() in ........\libraries\joomla\database\database\mysql.php on line 368

Как правильно такой код для 1.7 оформить?

*

savenko

  • Захожу иногда
  • 83
  • 8 / 0
Re: Подключение таблицы в J1.7
« Ответ #1 : 06.10.2011, 15:58:45 »
Первый вопрос откуда вызываешь таблицу из контроллера или модели?
Для контроллера скорее всего не указан префикс таблицы если компонент скажем называется Hello то должно стать так
$row=JTable::getInstance('Blogsection','HelloTable');

из метода можно вызвать таблицу так
$row=$this->getTable('Blogsection','HelloTable');

Есть ли у Вас таблица в компоненте в administrator/components/ ваш компонент?
Если нету то в папке tables должен лежать файл Blogsection.php такого типа:

<?php
// No direct access
defined('_JEXEC') or die('Restricted access');
 
// import Joomla table library
jimport('joomla.database.table');
 
/**
 * Hello Table class
 */
class helloTableBlogsection extends JTable
{
   
   function __construct(&$db)
   {
      parent::__construct('#__название таблицы', 'id', $db); //id должен быть primary key
   }
       
}


*

aldem67

  • Осваиваюсь на форуме
  • 12
  • 1 / 0
Re: Подключение таблицы в J1.7
« Ответ #2 : 08.10.2011, 15:12:50 »
Table и есть, как бы, префикс.

Код: php-brief
class TableBlogsection extends JTable{
}

Естественно таблица создана и tables/blogsection.php имеется.

В J1.5 он работает нормально. А вот при запуске на 1.7 такая ошибка вываливается. Пока сделал запросами, но хотелось бы заробраться.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вывод таблицы, деление на страницы

Автор March Cat

Ответов: 6
Просмотров: 1184
Последний ответ 09.01.2019, 18:49:15
от dmitry_stas
checkbox придать вид таблицы в файле XML

Автор xenos

Ответов: 5
Просмотров: 1643
Последний ответ 17.07.2017, 16:16:11
от vipiusss
Загрузить в форму компонента данные из другой таблицы БД

Автор fox7812

Ответов: 11
Просмотров: 1570
Последний ответ 26.05.2014, 22:11:30
от b2z
Подключение js файла и кнопка прикреления

Автор __noob__

Ответов: 6
Просмотров: 1841
Последний ответ 20.05.2014, 00:24:40
от Fedor Vlasenko
Компонент для редактирования таблицы БД

Автор maxsl_89

Ответов: 4
Просмотров: 1574
Последний ответ 27.03.2014, 13:24:57
от maxsl_89