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

С функцией динамические залоговки страниц   в TITLE с названием сайта выводится названия материала на странице. Это хорошо, но только не для главной страницы, где к названию добавляется - главная. Кто знает как оставить эту функцию, но на главной странице это слово не добавлять?
*

Bear

  • Захожу иногда
  • 67
  • 11 / 0
ну я сделал самым примитивным и простым способом: в includes\joomla.php чуть исправил функцию формирования заголовка и получил следующее

function setPageTitle( $title=null ) {
                if (@$GLOBALS['mosConfig_pagetitles']) {
                        $title = trim( htmlspecialchars( $title ) );
         $title = stripslashes($title);
         if ($title == "Главная") $title=""; // вот это дописал
                        $this->_head['title'] = $title ? $title . ' - '. $GLOBALS['mosConfig_sitename'] : $GLOBALS['mosConfig_sitename'];
                }
        }
не самый лучший и универсальный способ, но делается максимально быстро.
*

tysson

  • Захожу иногда
  • 263
  • 2 / 0
ну я сделал самым примитивным и простым способом: в includes\joomla.php чуть исправил функцию формирования заголовка и получил следующее

function setPageTitle( $title=null ) {
                if (@$GLOBALS['mosConfig_pagetitles']) {
                        $title = trim( htmlspecialchars( $title ) );
         $title = stripslashes($title);
         if ($title == "Главная") $title=""; // вот это дописал
                        $this->_head['title'] = $title ? $title . ' - '. $GLOBALS['mosConfig_sitename'] : $GLOBALS['mosConfig_sitename'];
                }
        }
не самый лучший и универсальный способ, но делается максимально быстро.

Сделал за 6 секунд! просто и универсально!
*

GapArchi

  • Захожу иногда
  • 81
  • 7 / 2
Спасибо, апнул тему помогло
*

Whiskas

  • Осваиваюсь на форуме
  • 35
  • 0 / 0
С функцией динамические залоговки страниц   в TITLE с названием сайта выводится названия материала на странице. Это хорошо, но только не для главной страницы, где к названию добавляется - главная. Кто знает как оставить эту функцию, но на главной странице это слово не добавлять?
Хочу добавить что если работает SEF или что то подобное, то нужно отключить функцию "Активировать Meta менеджмент" иначе будете долго лазить по форумам с красными глазами искать, почему у всех работает, а у меня нет :))
*

hohol

  • Новичок
  • 7
  • 0 / 0
А у меня index.php пустой  :o

<?php
/**
 * Legacy Mode compatibility
 * @version      $Id: Joomla.php 10381 2008-06-01 03:35:53Z pasamio $
 * @package      Joomla.Legacy
 */
require_once( dirname( __FILE__ ). '/application.php' );


Вот и все.Чо за фигня! Подскажите люди добрые !
*

anshakov

  • Осваиваюсь на форуме
  • 19
  • 0 / 0
А у меня index.php пустой  :o

<?php
/**
 * Legacy Mode compatibility
 * @version      $Id: Joomla.php 10381 2008-06-01 03:35:53Z pasamio $
 * @package      Joomla.Legacy
 */
require_once( dirname( __FILE__ ). '/application.php' );


Вот и все.Чо за фигня! Подскажите люди добрые !
Такая же ситуация. Может все таки кто подскажет выход. У меня установлен Artio JoomSEF, возможно с его помощью можно убрать это слово перед названием сайта на главной.
*

Yurets

  • Захожу иногда
  • 405
  • 92 / 0
  • Губернатор острова Борнео
Где находится ваш пустой index.php и что написано в application.php из той же папки?
В комнате с белым потолком
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Главная просела в выдаче

Автор Stasweb

Ответов: 2
Просмотров: 3917
Последний ответ 29.03.2025, 15:24:35
от azm1n
Редирект для страницы с добавлением кода языка

Автор zeus07

Ответов: 0
Просмотров: 2382
Последний ответ 26.06.2023, 11:25:10
от zeus07
Google не индексирует страницы через ajax ссылки

Автор illimited

Ответов: 0
Просмотров: 1425
Последний ответ 31.03.2022, 23:53:05
от illimited
Убрать из URL GET-параметр и сделать редирект на главную

Автор zeus07

Ответов: 8
Просмотров: 1086
Последний ответ 19.11.2021, 13:10:41
от zeus07
Не дело это - закрывать от индексации страницы с пагинацией

Автор ChaosHead

Ответов: 48
Просмотров: 11647
Последний ответ 04.11.2021, 06:44:26
от Slava77