Новости 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 Ответов
  • 2181 Просмотров
*

ybiza

  • Захожу иногда
  • 68
  • 4 / 0
Какой router.php править?
« : 12.05.2010, 20:07:36 »
Мне нужно чтобы материалы отображались вот так http://site/content/3/4.html где 3 id категория 4 id статья нашел вот что
Код
<?php
 
function QuickCatalogBuildRoute(&$query)
{
$segments = array();
 
    if (isset($query['task'])) {
        $segments[] = $query['task'];
        unset($query['task']);
    }  
    if (isset($query['category_id'])) {                  
        $segments[] = $query['category_id'];
        unset( $query['category_id'] );
    };                
    if (isset($query['id'])) {                  
        $segments[] = $query['id'];
        unset( $query['id'] );
    };
    unset($query['view']);    
    return $segments;
}
 
function QuickCatalogParseRoute($segments)
{  
    $vars = array();
$count = count($segments);
    switch ($count)
    {
        case 1:
            $vars['view'] = 'category';
            $vars['category_id'] = $segments[0];
            break;
        case 2:
            $vars['view'] = 'element';
            $vars['category_id'] = $segments[0];
            $vars['id'] = $segments[1];
            break;
        default:
            $vars['task'] = $segments[0];
            $vars['id'] = $segments[1];
    }
 
return $vars;
 
}
И вставил это дело в /components/com_content/router.php  заменив стандартную после чего сайт стал одним белым экраном. включен стандартный ЧПУ все три на "да" В чем  ошибка?  
*

Pencil

  • Осваиваюсь на форуме
  • 22
  • 0 / 0
  • Pencil-box.ru
Re: Какой router.php править?
« Ответ #1 : 25.05.2010, 21:54:43 »
Сам пытаюсь разобраться с подобной проблемой, пока дошол до формирования красивой ссылки, но не происходит перехода по ней.
Седалищным нервом чую, засада в переменных.
*

AzaLeo

  • Захожу иногда
  • 76
  • 2 / 0
Re: Какой router.php править?
« Ответ #2 : 06.06.2010, 12:56:48 »
Может кто-нибудь реализовывал такое: нужно из ссылки http://site/раздел/категория/id-материал.html сделать такую http://site/категория/материал.html , т.е. убрать /категория/ и id. Стоял компонент, который формировал ссылки такого вида, но хочу отказаться от него. Я так понял, что нужно править router.php, но не соображу, что именно. Материал читал по правке router.php, но на англ не совсем понятно.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Изменение SEF через правку router.php

Автор jouser

Ответов: 3
Просмотров: 1506
Последний ответ 05.12.2014, 11:27:25
от kitSS
Какой компонент лучше для создания sitemap и SEF?

Автор Millenium_3000

Ответов: 4
Просмотров: 1628
Последний ответ 03.09.2014, 19:07:39
от Millenium_3000
Router SEF

Автор MadChild

Ответов: 0
Просмотров: 1133
Последний ответ 24.07.2014, 16:53:05
от MadChild
Router для компонента

Автор limon142

Ответов: 0
Просмотров: 1221
Последний ответ 19.06.2014, 18:42:00
от limon142
Как правильно заменить intval id на string id в router.php?

Автор jelenpivo

Ответов: 1
Просмотров: 1363
Последний ответ 10.05.2014, 14:33:13
от zomby6888