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

Anhen71

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Добрый день!
На хостинге заменили PHP2 на PHP3.
На сайте http://www.dezentrum.nstu.ru/ исчезло Левое меню. Вот принтскрин этого сайта: http://gyazo.com/ebfeee5c4779cfb320b306f2268c0344
Может ли кто-то помочь решить проблему?
« Последнее редактирование: 04.12.2012, 20:03:42 от b2z »
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: При переходе на PHP3 пропало меню
« Ответ #1 : 03.12.2012, 19:47:16 »
Добрый.

Вы наверное имели ввиду 5.2 на 5.3? А каким модулем выводилось это меню?
*

Anhen71

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Re: При переходе на PHP3 пропало меню
« Ответ #2 : 03.12.2012, 20:48:30 »
Да, ошиблась, было PHP2, стало PHP3. Модуль - mod_mainmenu. Закинула этот сайт на свой хост - там PHP2 - все нормально - вот как выглядит: http://demo.lis77.ru И в админке в Все меню/Левое меню, Все меню/Главное меню все нормально

На родном же хосте с РНР3 в Все меню/левое меню, да и в Все меню/Главное меню вот такая картина:
http://gyazo.com/54c1e2bb04dc5f25056b895348af4e65
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: При переходе на PHP3 пропало меню
« Ответ #3 : 03.12.2012, 22:24:18 »
Видимо есть какая-то несовместимость с PHP 5.3, тяжело сказать в чем именно. Попробуйте на тестовом сайте обновить Joomla до 1.5.26, а то у Вас очень старая версия.
*

Anhen71

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Re: При переходе на PHP3 пропало меню
« Ответ #4 : 04.12.2012, 01:00:04 »
Спасибо, попробую.
Вот что мне ответили на другом форуме:

"Попробуйте сделать так. Откройте файл ваш сайт/libraries/joomla/html/html.php. Примерно на 80-82 строке немного исправьте код. Должно получиться так:
Код
01
if (is_callable( array( $className, $func ) ))
02
                {
03
                        $args = func_get_args();
04
                        array_shift( $args );
05
 
06
                        // PHP 5.3 workaround
07
                        $temp   = array();
08
                        foreach ($args AS &$arg) $temp[] = &$arg;
09
 
10
                        return call_user_func_array( array( $className, $func ), $args );
11
                }

Я попробовала это сделать, но редактор ругался, и мне на форуме ответили, что функция array_shift() встроена в php начиная с 4 версии. В php 3 версии она не поддерживается. Нужно либо написать аналог данной функции, либо перейти на php более новой версии(от 4). Второй вариант предпочтительней.  Перейти на 4-ю версию невозможно в силу свойств хостинга, а написать аналог данной функции у меня не хватает знаний.
*

Anhen71

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Re: При переходе на PHP3 пропало меню
« Ответ #5 : 04.12.2012, 11:51:53 »
Я ошиблась в вопросе - была версия РНР 5.2, а стала РНР 5.3. Может кто-то сталкивался с такой проблемой?
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Re: При переходе на PHP3 пропало меню
« Ответ #6 : 04.12.2012, 12:02:10 »
У меня есть сайт на Joomla 1.5 и версия php5.3 стоит - все работает нормально.
А какая версия 1.5 у Вас - может обновлений не хватает.
Сейчас актуальная версия 1.5.26
Если у Вас ниже, то попробуйте обновиться.
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Re: При переходе на PHP3 пропало меню
« Ответ #7 : 04.12.2012, 16:22:21 »
Anhen71, смотрю меню заработало.
Что сделали?
Если проблему решили, то отпишитесь здесь.
Вдруг у кого еще такая проблема возникнет.
*

Anhen71

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Re: При переходе на PHP3 пропало меню
« Ответ #8 : 04.12.2012, 18:35:02 »
Да-да, как раз хотела написать - последовала Вашему и b2z совету, обновила Joomla до 1.5.26 и все заработало! Большое спасибо!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

убрать из меню заголовки 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