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

borada

  • Захожу иногда
  • 182
  • 13 / 0
Приходится делать текст меню сокращенным, вплоть до абревиатуры. Хотелось бы чтоб при наведении на пункт меню всплывало более подробное описание. Для статей такое видел, для меню не нашел. Есть такое? Ткните носом пожалуйста, или скажите что в поиск набрать...
*

SinBad

  • Завсегдатай
  • 1879
  • 187 / 0
  • Мнне 40 лет, мне 40 лет, ума так и не нажил!
(на забудте сделать бэкап файлов, которые будете изменять на случай ошибки и отката):
 
Вверху файла – модуля меню modules/mod_mainmenu.php заменить строку
global $Itemid, $mosConfig_live_site, $mainframe;
 
на строку:
global $Itemid, $mosConfig_live_site, $mainframe, $database;
 
Затем ниже заменить:
                        $mitem->name = stripslashes( ampReplace($mitem->name) );
 
                        switch ($mitem->browserNav) {
                                   // различные события
                                   case 1:
                                   // открыть в новом окне
                                   $txt = '<a href="'. $mitem->link .'" target="_blank" class="'. $menuclass .'" '. $id .'>'. $mitem->name .'</a>';
                                   break;
 
                                   case 2:
                                   // открытие во всплывающем окне
                                   $txt = "<a href=\"#\" onclick=\"javascript: window.open('". $mitem->link ."', '', 'toolbar=no,location=no,status=no,menubar=no,scrollbars=yes,resizable=yes,width=780,height=550'); return false\" class=\"$menuclass\" ". $id .">". $mitem->name ."</a>\n";
                                   break;
 
                                   case 3:
                                   // это не ссылка
                                   $txt = '<span class="'. $menuclass .'" '. $id .'>'. $mitem->name .'</span>';
                                   break;
 
                                   default:
                                   // открытие в текущем окне
                                   $txt = '<a href="'. $mitem->link .'" class="'. $menuclass .'" '. $id .'>'. $mitem->name .'</a>';
                                   break;
                        }
На этот код:
 
// SEO-joomla hack START
$table_menu = "#__menu";
$query_title = "SELECT params" . "\n FROM $table_menu" . "\n WHERE id = $mitem->id";
$database->setQuery( $query_title );
$rows_sel = $database->loadResult();
preg_match("/link_title=(.+)/",$rows_sel,$matches);
if (empty($matches[1])) {
$link_title = htmlspecialchars(stripslashes($mitem->name));
}
else {
$link_title = htmlspecialchars(stripslashes($matches[1]));
}
 
 
                        switch ($mitem->browserNav) {
                                   // различные события
                                   case 1:
                                   // открыть в новом окне
                                   $txt = '<a href="'. $mitem->link .'" target="_blank" class="'. $menuclass .'" '. $id .' title="'. $link_title .'">'. $mitem->name .'</a>';
                                   break;
 
                                   case 2:
                                   // открытие во всплывающем окне
                                   $txt = "<a href=\"#\" onclick=\"javascript: window.open('". $mitem->link ."', '', 'toolbar=no,location=no,status=no,menubar=no,scrollbars=yes,resizable=yes,width=780,height=550'); return false\" class=\"$menuclass\" ". $id ." title=\"$link_title\">". $mitem->name ."</a>\n";
                                   break;
 
                                   case 3:
                                   // это не ссылка
                                   $txt = '<span class="'. $menuclass .'" '. $id .'>'. $mitem->name .'</span>';
                                   break;
 
                                   default:
                                   // открытие в текущем окне
                                   $txt = '<a href="'. $mitem->link .'" class="'. $menuclass .'" '. $id .' title="'. $link_title .'">'. $mitem->name .'</a>';
                                   break;
                        }
// SEO-joomla hack END
 
После – во всех файлах
/administrator/components/com_menus/***folder***/***.menu.html.php
 
вставить эту дополнительную строчку в таблицу (я это сделал сразу после строки с названием ссылки):
 
           <tr>
                <td align="right"><SPAN
class=editlinktip><!-- Tooltip --><SPAN onmouseover="return overlib('Описание ссылки, которое видно при наведении курсора на нее (параметр ссылки title - улучшает SEO оптимизацию страницы).', CAPTION, 'Описание ссылки', BELOW, RIGHT);" onmouseout="return nd();">Описание ссылки</SPAN></SPAN></td>
<?
global $database;
$query_title = "SELECT params" . "\n FROM #__menu" . "\n WHERE id = $menu->id";
$database->setQuery( $query_title );
$rows_sel = $database->loadResult();
preg_match("/link_title=(.+)/",$rows_sel,$matches);
if (empty($matches[1])) {
$link_title = '';
}
else {
$link_title = $matches[1];
}
?>
 
                <td><textarea class="text_area" name="params[link_title]" cols="30"><? echo $link_title; ?></textarea>
                </td>
            </tr>
 
Готово…
...Фет для них песни поёт. Фет не прикольный поэт - Фету никто не даёт.
*

borada

  • Захожу иногда
  • 182
  • 13 / 0
Вот спасибо. Буду пробовать.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Правильная организация меню в материале

Автор kompmen

Ответов: 3
Просмотров: 780
Последний ответ 23.10.2021, 01:29:55
от kompmen
Есть такой компонент для Joomla

Автор Stasweb

Ответов: 6
Просмотров: 909
Последний ответ 17.08.2021, 19:20:45
от effrit
Посоветуйте модуль меню Joomla

Автор lgmax

Ответов: 3
Просмотров: 1000
Последний ответ 17.12.2020, 02:48:01
от v42bis
Расчёт цены золота. Есть пример

Автор digree

Ответов: 7
Просмотров: 1628
Последний ответ 20.02.2020, 18:36:41
от beliyadm
Ресторанное меню + доставка

Автор Raz0r

Ответов: 0
Просмотров: 726
Последний ответ 05.02.2020, 22:30:50
от Raz0r