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

Fomen

  • Захожу иногда
  • 99
  • 4 / 0
  • Землю крестьянам!!!
Альтернативный фон
« : 25.08.2010, 12:23:15 »
Ребят, всем привет. Нужна ваша помощь. Как в шаблоне Joomla 1.5 изменить что-либо в зависимости от открытой странички (меня интересует главная), кто знает, напишите пожалуйста обобщённый код отслеживания главной страницы, и обьясните куда вставлять. А именно, мне нужен альтернативный фон главной страницы. Чтобы на главной на фоне была картинка, а на других страницах другой фон.
Заранее спасибо.
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
Re: Альтернативный фон
« Ответ #1 : 25.08.2010, 12:46:42 »
го сюда:
http://joomlaforum.ru/index.php/topic,67278.new.html
там есть условие на проверку на главную страницу. ставишь его в нужном тебе месте и в зависимости от него выводишь разные строки.
типа
<div background="1.jpg">
else
<div background="2.jpg">
*

Fomen

  • Захожу иногда
  • 99
  • 4 / 0
  • Землю крестьянам!!!
Re: Альтернативный фон
« Ответ #2 : 25.08.2010, 12:51:50 »
Спасибо большое. Буду смотреть
*

danik.html

  • Живу я здесь
  • 2650
  • 353 / 4
Re: Альтернативный фон
« Ответ #3 : 25.08.2010, 13:02:03 »
<?php
   $active = JSite::getMenu()->getActive();
   if (isset($active)) {
      $params = new JParameter($active->params);
      $suffix = $params->get('pageclass_sfx');
   } else {
      $suffix = '_default';
   }

?>
<body class="page<?php echo $suffix ?>"


Далее в менеджере меню прописываеть главному пункту в параметрах суффикс скажем _main или _home

или используй условия в шаблоне(ищи на форуме)
【Мегапак Virtuemart:
 • метатеги (description,keywords)
 • заголовки (title)
 • красивые алиасы (чпу) без тормозов и дублей!
*

Roberta

  • Захожу иногда
  • 182
  • 0 / 0
Re: Альтернативный фон
« Ответ #4 : 24.12.2010, 09:08:48 »
<?php
   $active = JSite::getMenu()->getActive();
   if (isset($active)) {
      $params = new JParameter($active->params);
      $suffix = $params->get('pageclass_sfx');
   } else {
      $suffix = '_default';
   }

?>
<body class="page<?php echo $suffix ?>"


Далее в менеджере меню прописываеть главному пункту в параметрах суффикс скажем _main или _home

или используй условия в шаблоне(ищи на форуме)

Сделала как вы сказали все работает спасибо. Но у меня сайт на 2-х языках и соответственно при переключении на другой язык фоновые картинки пропадают как сделать чтобы они оставались
Что-то типа этого, но так вообще вроде неправильно, не работает:

    <?php if ($show_topads) : ?>
    <?php switch ($this->getlanguage()){
   case 'en-gb':?><body class="page<?php echo $suffix ?>">
    <?php   
  break;
  case 'de-de':?><body class="page<?php echo $suffix ?>">
  <?php   
  break;
  default :?><body class="page<?php echo $suffix ?>">
        </div>  <?php
  break;
  }
  ?>   
    <?php endif;?>
« Последнее редактирование: 24.12.2010, 09:13:12 от Roberta »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как настроить статьи, или альтернативный компонент

Автор qivi

Ответов: 5
Просмотров: 1980
Последний ответ 25.08.2009, 08:26:28
от sav_83