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

Provolod

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
Сейчас я сделал кнопку для добавления видео в таком формате
вогнал в кастом модуль вот такую строчку
<p><a href="javascript:void(0);" onclick="joms.videos.addVideo()"><img src="/images/add-video.png" border="0" alt="Добавить видео" style="border: 0;" /></a></p>

но она работает только на страницах сайта, связаных с jomsocial. На главной просто не отрабатывает скрипт. Видимо на ней не хватает чего то. Как можно сделать так, чтобы эта кнопка работала на всех страницах сайта?
*

PashkaRu

  • Давно я тут
  • 941
  • 91 / 4
  • Дедушка Игнат, изыди ((((
посмотреть, какой скрипт за это отвечает. значит, вероятно, он не подгружается, если открыто что-то, кроме комьюнити.

прописать этот скрипт в index.php шаблона.
+
*

AlexAl

  • Захожу иногда
  • 309
  • 13 / 0
не уверен попробуй добавить в шаблон троки

defined('_JEXEC') or die();
require_once( JPATH_ROOT . DS . 'components' . DS . 'com_community' . DS . 'libraries' . DS . 'core.php');
require_once( JPATH_ROOT . DS . 'components' . DS . 'com_community' . DS . 'helpers' . DS . 'string.php' );
в начале
*

Provolod

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
Ребята, спасибо вам огромное. Все получилось. В хедер шаблона просто вписал строки
  <link rel="stylesheet" href="http://www.domain.com/components/com_community/templates/pochti-default/css/style.css" type="text/css" />
  <link rel="stylesheet" href="http://www.domain.com/components/com_community/assets/window.css" type="text/css" />
  <link rel="stylesheet" href="http://www.domain.com/components/com_community/assets/autocomplete.css" type="text/css" />

  <script type="text/javascript" src="http://www.domain.com/components/com_community/assets/jquery-1.3.2.pack.js"></script>
  <script type="text/javascript" src="http://www.domain.com/components/com_community/assets/window-1.0.js"></script>
  <script type="text/javascript" src="http://www.domain.com/components/com_community/assets/script-1.2.js"></script>

и даже подправил тулстип как выяснилось. а то думал как его править и не мог вообще понять откуда начать копать. осталось только теперь вытащить для него цcc из jomsocial. но это дело пятое. уже стало лучше и так. хотя по хорошему конечно нужно сейчас это сделать. попробую выдернуть цсску на морду тоже.
*

Darknemo

  • Захожу иногда
  • 223
  • 2 / 0
Кстати эту же фишку можно сделать с жалобами.. на весь сайт..;)
Там ведь в жалобах идет ссылка на соответствующую страничку =) спс за наводку ) 
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Смена шаблона сайта пользователем

Автор 321

Ответов: 3
Просмотров: 2377
Последний ответ 17.02.2014, 16:55:50
от 321
Как изменить размер миниатюр видео?

Автор SaSHoK76

Ответов: 11
Просмотров: 3847
Последний ответ 09.06.2013, 22:24:49
от webday
Как показать список материалов, опубликованных пользователем рядом с видео и фото пользователя?

Автор Igor Rome

Ответов: 5
Просмотров: 2546
Последний ответ 03.02.2013, 13:51:55
от vs-161
Отображение фото и видео в popup-окнах

Автор Pablik_Escobar

Ответов: 6
Просмотров: 3136
Последний ответ 09.07.2012, 03:44:47
от andrew_x_
Пропала кнопка входа!

Автор Torri30

Ответов: 1
Просмотров: 1706
Последний ответ 02.03.2012, 16:36:56
от Torri30