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

Mr_SMiT

  • Осваиваюсь на форуме
  • 34
  • 0 / 0
Спойлеры и Аккордионы
« : 08.11.2009, 12:19:16 »
Видят ли поисковики контент под спойлерами, аккордионами, вкладками и др. мишурой?
*

Mr_SMiT

  • Осваиваюсь на форуме
  • 34
  • 0 / 0
Re: Спойлеры и Аккордионы
« Ответ #1 : 11.11.2009, 16:54:13 »
Ребята, я серьезно, нет в данный момент возможности, посмотрите пожалуйста в инструментах Гула какую-нибудь страничку с этими прибамбахами, помнится была там такая возможность "Посмотреть как робот видит"
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Спойлеры и Аккордионы
« Ответ #2 : 11.11.2009, 16:58:08 »
если контент грузится не на AJAX - прекрасно видят, достаточно посмотреть исходный код страницы и вопрос решен
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Mr_SMiT

  • Осваиваюсь на форуме
  • 34
  • 0 / 0
Re: Спойлеры и Аккордионы
« Ответ #3 : 11.11.2009, 17:04:25 »
если контент грузится не на AJAX - прекрасно видят, достаточно посмотреть исходный код страницы и вопрос решен
Позвольте логичный тогда вопрос. Какие из них не на AJAX? Чтоб не ставит все подряд. Требуется для прайса открывать категории таким образом. Конечно если не затруднит.
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Спойлеры и Аккордионы
« Ответ #4 : 11.11.2009, 17:06:21 »
Какие из них не на AJAX? Чтоб не ставит все подряд. Требуется для прайса открывать категории таким образом. Конечно если не затруднит.
я откуда знаю :)
90% всех подобных вещей - никакого AJAX, весь контент грузится в страницу и после оборачивается в JS, то есть все нормально индексируется
Как проверить - установить, включить и смотреть исходный код либо читать документацию на сайте авторов
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Mr_SMiT

  • Осваиваюсь на форуме
  • 34
  • 0 / 0
Re: Спойлеры и Аккордионы
« Ответ #5 : 11.11.2009, 17:37:46 »
Но ссылки то, реализованные через любые скрипты, поиковики ведь не видят?! А контент выходит видят?
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Спойлеры и Аккордионы
« Ответ #6 : 11.11.2009, 17:41:42 »
Но ссылки то, реализованные через любые скрипты, поиковики ведь не видят?! А контент выходит видят?
это почему?

Код: html4strict
<ul>
 <li>текст 1 <a href="">link></li>
 <li>текст 2 <a href="">link></li>
 <li>текст 3 <a href="">link></li>
</ul>
Вот это обычная структура многих аккордеонов и спойлеров, только смысл JS в том что по умолчанию они скрыты либо находятся за пределами видимости блока.
Но целиком загружаются в исходный код страницы и лишь только после обрабатываются скриптом.
Так что поисковик все прекрасно видит
Но - если это только не AJAX (когда содержимое блока грузится только при необходимости) либо что то специфичное
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

vagkrsk

  • Давно я тут
  • 731
  • 125 / 0
  • Дорогу осилит идущий
Re: Спойлеры и Аккордионы
« Ответ #7 : 11.11.2009, 17:42:50 »
Mr_SMiT с тобой разговаривает разработчик программы, которую я тебе посоветовал.
Задавай конкретные вопросы. Приведи в пример сайт, если сайт на хостинге.
Не теряй момент  ^-^
« Последнее редактирование: 11.11.2009, 17:58:40 от vagkrsk »
*

Mr_SMiT

  • Осваиваюсь на форуме
  • 34
  • 0 / 0
Re: Спойлеры и Аккордионы
« Ответ #8 : 11.11.2009, 17:46:23 »
Mr_SMiT с тобой разговаривает разработчик программы, которую я тебе посоветовал.
Задавай конкретные вопросы. Приведи в пример сайт, если сайт на хостинге.
Спасибо! Пока в локале. Как только буду готов обязательно задам вопросы на этом форуме (если будут).
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Спойлеры и Аккордионы
« Ответ #9 : 11.11.2009, 17:46:35 »
Mr_SMiT с тобой разговаривает разработчик программы, которую я тебе посоветовал.
что за программа?
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

vagkrsk

  • Давно я тут
  • 731
  • 125 / 0
  • Дорогу осилит идущий
Re: Спойлеры и Аккордионы
« Ответ #10 : 11.11.2009, 17:47:08 »
spoiler
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Спойлеры и Аккордионы
« Ответ #11 : 11.11.2009, 17:47:40 »
spoiler
понял, там надо все к чертям переписать по умному, никак руки не дойдут
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Sorbon

  • Захожу иногда
  • 80
  • 1 / 0
Re: Спойлеры и Аккордионы
« Ответ #12 : 11.11.2009, 20:29:15 »
А как например сделать, как на этом сайте http://psynavigator.ru/  "ВЫБРАТЬ ПСИХОЛОГА / ЦЕНТР"

Мне сказали, что это Ajax+поиск. Я понятие не имею как это сделать на Joomla 1,5. Может есть компонент, который все это реализует? Чтобы при выборе из аккордеонов выдал результат поиска на отдельной странице.

Ценю любою вашу информацию.
Спасибо за ранее!
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Спойлеры и Аккордионы
« Ответ #13 : 11.11.2009, 20:38:06 »
А как например сделать, как на этом сайте http://psynavigator.ru/  "ВЫБРАТЬ ПСИХОЛОГА / ЦЕНТР"
никакого AJAX, чистый JS (не надо путать понятия визуального эффекта и асинхронного запроса)
Изначально подгрузили два блока с разными формами поиска, две ссылки. Один блок сразу скрыт (display: none;), по клику это свойство переходит к показанному блоку и снимается с скрытого.
Соответственно что выбрали - та форма и покажется

А в указанном случае все еще проще - в заисимости от выбранного пункта меняется лишь скрытый параметр формы и текст кнопки, который собственно в обработчике уже и говорит скрипту - что искать

Готового нет естественно один в один, но есть похожие решения, есть гугль, есть умные книги, реализовать подобное - минут 20-30 (естественно при наличии определенного опыта и знаний)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Sorbon

  • Захожу иногда
  • 80
  • 1 / 0
Re: Спойлеры и Аккордионы
« Ответ #14 : 11.11.2009, 21:08:15 »
могу с Вами согласовать этот вопрос? конечно не за просто так :)  прошу Вас напишите мне: аська  350219219
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Спойлеры и Аккордионы
« Ответ #15 : 11.11.2009, 21:09:57 »
можете, но только после субботы, до того категорически занят и ленюсь, стукните в личку в субботу после обеда, обсудим
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Sorbon

  • Захожу иногда
  • 80
  • 1 / 0
Re: Спойлеры и Аккордионы
« Ответ #16 : 11.11.2009, 21:14:16 »
жаль :(  мне так  надо ... ну что поделать.. раз категорически заняты...
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Спойлеры и Аккордионы
« Ответ #17 : 11.11.2009, 21:16:27 »
жаль :(  мне так  надо ... ну что поделать.. раз категорически заняты...
если собственно формы и обработчики у вас готовы и есть необходимость повторить только лишь функционал переключения - то можно завтра
Озвучьте целиком задачу с максимальными входными параметрами. Сами же понимаете - чем меньше времени я (и не только) потрачу на понимание задачи - тем быстрее и дешевле выйдет результат.
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться