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

haidamaka

  • Осваиваюсь на форуме
  • 44
  • 1 / 0
Как сделать смену фона шапки для каждого пункта меню. Раньше я делал это с помощью создания нескольких шаблонов, которым был присвоен каждый пункт меню, но для большого сайта с 3-мя языками это очень проблематично. Кто может подсказать более простой способ?
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
http://joomlaforum.ru/index.php/topic,28744.0.html и много других примеров аналогичного вопроса в поиске
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

BaR

  • Захожу иногда
  • 86
  • 6 / 0
Вставьте модуль вместо шапки, создайте  модуль на сайте, поместите в него код хтмл вашей шапки и опубликуйте его для нужных меню, для других меню та же самая процедура, или з приведенного выше примера
*

haidamaka

  • Осваиваюсь на форуме
  • 44
  • 1 / 0
спасибо большое за интересные решения. выбрал первый способ.
*

puppet1

  • Новичок
  • 6
  • 0 / 0
http://joomlaforum.ru/index.php/topic,28744.0.html и много других примеров аналогичного вопроса в поиске
Если же нам требуется просто поместить разные картинки на разные пункты меню, то будет выглядеть примерно так:
Код:
<?php
   if (@$Itemid == '11' ) { echo "<img src='images/ico/1.gif' border='0' />";
   } elseif (@$Itemid == '12' ) { echo "<img src='images/ico/2.gif' border='0' />";
   } elseif (@$Itemid == '13' ) { echo "<img src='images/ico/3.gif' border='0' />";
   } else {}
?>
Применила данную схему на локалке - все работает!
На хосте - НЕ работает!!!
Пожалуйста, помогите разобраться в чем ошибка.
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
сделайте на хосте
Код
echo $Itemid;
и смотрите - отдается ли корректно нужное значение для разных страниц.
Возможно кеш шалит либо сторонние компоненты  SEF  либо что еще
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

puppet1

  • Новичок
  • 6
  • 0 / 0
сделайте на хосте
Код
echo $Itemid;
и смотрите - отдается ли корректно нужное значение для разных страниц.
Возможно кеш шалит либо сторонние компоненты  SEF  либо что еще
Пыталась вставить в код,
Код
echo $Itemid;
но безрезультатно.
Посмотрите, плиз, где ошибка!

<div id="jsn-logo"><?php if ($logo_link != "") echo '<a href="'.$logo_link.'" title="'.$logo_text.'">'; ?><img src="<?php echo $logo_image;?>" width="<?php echo intval($logo_width); ?>" height="<?php echo intval($logo_height); ?>" alt="<?php echo $logo_text; ?>" /><?php if ($logo_link != "") echo '</a>'; ?> <?php echo $Itemid; ?>
           
            <?php echo $Itemid; ?>
           
             <?php if (@$Itemid == '32' ) { echo "<img src='templates/jsn_epic_free/images/logo1.jpg' border='0' />";
   } elseif (@$Itemid == '56' ) { echo "<img src='templates/jsn_epic_free/images/logo1.jpg' border='0' />";
   } elseif (@$Itemid == '55' ) { echo "<img src='templates/jsn_epic_free/images/logo1.jpg' border='0' />";
   }else {}
   
?>     
            </div>
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
для начала не @$Itemid а просто $Itemid
Дальше в начале где нить надо сделать
Код: php
$Itemid = JRequest::getInt( 'Itemid', 1, 'get' );
и уже после делать
Код: php
echo $Itemid;
и дальнейшие условия
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

puppet1

  • Новичок
  • 6
  • 0 / 0
для начала не @$Itemid а просто $Itemid
Дальше в начале где нить надо сделать
Код: php
$Itemid = JRequest::getInt( 'Itemid', 1, 'get' );
и уже после делать
Код: php
echo $Itemid;
и дальнейшие условия
Спасибо Вам огромное, теперь все работает!!!
*

Andres1989

  • Новичок
  • 3
  • 0 / 0
Спасибо Вам огромное, теперь все работает!
можно показать конечный код?
*

Andres1989

  • Новичок
  • 3
  • 0 / 0
Прочитав эту тему, найдете решение CSS-класс страницы
а конкретно тыкнуть носом начинающего сложно?
темболее там расматривается Joomla 2.5, я использую Joomla 1.5
« Последнее редактирование: 12.09.2014, 12:02:52 от Andres1989 »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

убрать из меню заголовки h3

Автор nexter

Ответов: 19
Просмотров: 8692
Последний ответ 03.02.2020, 18:49:47
от durte
При добавлении нового пункта меню не отображается содержимое

Автор Denko

Ответов: 2
Просмотров: 3815
Последний ответ 16.01.2020, 18:40:55
от Denko
Не нажимается пункт меню на мобильной версии

Автор Sensession

Ответов: 7
Просмотров: 5466
Последний ответ 04.01.2020, 16:45:27
от xpank
Не отображаются пункты в меню

Автор physic

Ответов: 20
Просмотров: 23939
Последний ответ 20.09.2019, 16:54:01
от beliyadm
Как в ARI Ext Menu добиться работы параметра "Показать в меню"?

Автор vasmed

Ответов: 1
Просмотров: 4162
Последний ответ 01.03.2019, 11:12:18
от vasmed