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

Mr.Friction

  • Захожу иногда
  • 81
  • 1 / 6
Проблема с ЧПУ и меню.
« : 18.06.2011, 00:00:09 »
Собственно создаю пункт меню и пункт под меню например

пункт - news
под пункт - news1 news2

получаю юрлы вида domain.com/news/news1/ststya.html (на главной и т.д.)
получаю юрлы вида domain.com/news/news2/ststya.html (на главной и т.д.)


после чего создаю меню
пункт - news1 news2

получаю ВЕЗДЕ юлп вида
domain.com/news1/ststya.html
domain.com/news2/ststya.html

то есть совершенно другие юрл-ы (и самое большое заподло в том что все юрлы становятся этого вида)
*

Mihanja80

  • Завсегдатай
  • 1918
  • 168 / 4
  • Всю жизнь учусь...
Re: Проблема с ЧПУ и меню.
« Ответ #1 : 18.06.2011, 00:39:52 »
можно ещё создать прямую ссылку на статью, и снова ссылки поменяются...
Это же закономерность в работе стандартного функционала Joomla...
Я с мобильного, в основном...
*

Mr.Friction

  • Захожу иногда
  • 81
  • 1 / 6
Re: Проблема с ЧПУ и меню.
« Ответ #2 : 19.06.2011, 02:08:46 »
Так а есть вообще решение этой проблемы?
*

Mr.Friction

  • Захожу иногда
  • 81
  • 1 / 6
Re: Проблема с ЧПУ и меню.
« Ответ #3 : 21.06.2011, 12:48:40 »
Люди добрые - вопрос очень актуален.
На Joomla 1.6 тоже такая фигня?
*

Email

  • Захожу иногда
  • 75
  • 4 / 0
Re: Проблема с ЧПУ и меню.
« Ответ #4 : 22.06.2011, 12:03:55 »
непонятно - речь идет о пунктах меню и подпунктах меню?
Т.е.

-news
|--news1
|--news2

или все-таки о равноуровневых пунктах?
Т.е.

-news
-news1
-news2

В первом случае все будет нормально и статья будет лежать по адресу ".../news/news1/статья".
А во втором - да, ".../news/" из адресов пропадет (или материал продублируется и по этому адресу тоже). Только если news1 и news2 - подпункты общего пункта news, то непонятно, зачем вам идти вторым путем, сделайте по первому типу и такой проблемы не будет.
*

GDV

  • Завсегдатай
  • 1898
  • 201 / 5
Re: Проблема с ЧПУ и меню.
« Ответ #5 : 22.06.2011, 12:09:58 »
Переписать роутер. Уже вроде где то на форуме было решение. Ищите.
Все урлы формируются на основе роутера. Если там есть показывать например алиас категории, то он будет исправно добавляться в урлу.

И всё в таком же духе.
Убедительная просьба не писать в ЛС. Для решения Ваших проблем есть форум.
*

Mr.Friction

  • Захожу иногда
  • 81
  • 1 / 6
Re: Проблема с ЧПУ и меню.
« Ответ #6 : 23.06.2011, 22:53:23 »
непонятно - речь идет о пунктах меню и подпунктах меню?
Т.е.

-news
|--news1
|--news2

или все-таки о равноуровневых пунктах?
Т.е.

-news
-news1
-news2

В первом случае все будет нормально и статья будет лежать по адресу ".../news/news1/статья".
А во втором - да, ".../news/" из адресов пропадет (или материал продублируется и по этому адресу тоже). Только если news1 и news2 - подпункты общего пункта news, то непонятно, зачем вам идти вторым путем, сделайте по первому типу и такой проблемы не будет.

Если я сделаю ещё одно меню, то всёравно от пункта news мне никуда не деться.

То есть смысл в том, что у меня есть верхнее меню вида
-news
|--news1
|--news2

но мне ещё необходимо сделать дополнительное меню
news1
news2

чтоб это меню отображалось в самой новости (типа перелинковка).

Переписать роутер. Уже вроде где то на форуме было решение. Ищите.
Все урлы формируются на основе роутера. Если там есть показывать например алиас категории, то он будет исправно добавляться в урлу.

И всё в таком же духе.

Да перерыл форум - не могу найти...


А если ещё точнее, то мне необходимо чтоб в ссылках перед категорией был раздел.

Типа такого: http://domain.com/section/category/page_name.html
« Последнее редактирование: 23.06.2011, 23:00:37 от Mr.Friction »
*

Email

  • Захожу иногда
  • 75
  • 4 / 0
Re: Проблема с ЧПУ и меню.
« Ответ #7 : 24.06.2011, 00:13:21 »
но мне ещё необходимо сделать дополнительное меню
news1
news2

Тогда создайте в этом втором меню пункты меню по типу "псевдоним" (в самом низу списка типов пунктов меню при создании нового пункта), а там выберите уже существующие пункты меню (news1, news2) - в таких случаях не создается новый урл, а берется тот, к которому этот псевдоним привязывается.

Т.е. у вас будет

Меню 1
-news (урл - ввв.сайт.ру/news.хтмл)
|--news1 (урл - ввв.сайт.ру/news/news1.хтмл)
|--news2 (урл - ввв.сайт.ру/news/news2.хтмл)

Меню 2
-news1 (урл - ввв.сайт.ру/news/news1.хтмл, т.е. идентичный пункту news1 меню 1)
-news2 (урл - ввв.сайт.ру/news/news2.хтмл, т.е. идентичный пункту news2 меню 1)

И всего делов.
« Последнее редактирование: 24.06.2011, 00:17:04 от Email »
*

Mr.Friction

  • Захожу иногда
  • 81
  • 1 / 6
Re: Проблема с ЧПУ и меню.
« Ответ #8 : 24.06.2011, 01:15:31 »
Спасибо тебе добрый человек......
А ещё вопрос.
Если я выведу например популярные записи ведь у них тоже "кривые URL" будут?
*

Email

  • Захожу иногда
  • 75
  • 4 / 0
Re: Проблема с ЧПУ и меню.
« Ответ #9 : 24.06.2011, 09:30:13 »
нет, урлы будут те же, что и через меню. Модуль "популярные записи" сам урлы не создает, а только ставит ссылки на существующие.
*

Mr.Friction

  • Захожу иногда
  • 81
  • 1 / 6
Re: Проблема с ЧПУ и меню.
« Ответ #10 : 26.06.2011, 00:26:06 »
И ещё раз спасибо !
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

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

Автор nexter

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

Автор Denko

Ответов: 2
Просмотров: 3816
Последний ответ 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
Просмотров: 4163
Последний ответ 01.03.2019, 11:12:18
от vasmed