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

shadowrun

  • Захожу иногда
  • 78
  • 1 / 0
страница результата поиска имеет такой URL
htpp://site.ru/shop/search/result.html

Если использовать простой поиск - то прямой URL на результат имеет примерно такой вид:
http://site.ru/index.php?option=com_jshopping&controller=search&task=result&search=телевизор

но вот.. если использовать расширенный поиск и там фигурируют различные характеристики, производители, категории ( например ищется телевизор фирмы SONY с full hd - как получить тот URL?

ну или где хотябы искать?

« Последнее редактирование: 18.04.2014, 12:06:18 от shadowrun »
*

shadowrun

  • Захожу иногда
  • 78
  • 1 / 0
разобрался.
чтото типа такого
http://site.ru/index.php?option=com_jshopping&controller=search&task=result&extra_fields[4]=49&extra_fields[10]=88&extra_fields[2]=4x0,7
*

ardemish

  • Осваиваюсь на форуме
  • 18
  • 0 / 0
Привет. Чтобы не создавать лишние темы, попробую здесь задать вопрос.
Необходимо иметь ссылку на результат поиска, чтобы использовать эту страницу как посадочную для контекста, характеристики при этом не обязательны, просто по наименованию или тексту описания.
На сайте используется стандартный плагин от разработчиков: Search 4.01, и стандартный модуль поиска: 4.1.0. Joomla 3.5.1 JoomShopping 4.14.1
Ссылку делаю следующую:  http://сайт/index.php?option=com_jshopping&controller=search&task=result&search_type=all&category_id=1&include_subcat=1&search=ключ поиска
ссылка работает и все ок. Меняю ключи и поиск срабатывает
НО:
если воспользоваться модулем поиска и ввести, допустим: "ключ поиска 1", то после этого поиск по ссылке перестает работать, а выводится страница с результатами последнего поиска, произведенного через модуль, т.е. результаты для "ключ поиска 1". Поиск через модуль продолжает нормально работать. И так до окончания сессии.

Искал решение и на форуме и в интернете, так ничего и не нашел по этому вопросу, неужели никто не формирует посадочные страницы для контекста в зависимости от запроса пользователя? Не верю. Может есть решение, но я плохо искал?
Заранее спасибо, если кто-то поможет
« Последнее редактирование: 14.07.2016, 12:24:16 от ardemish »
*

ardemish

  • Осваиваюсь на форуме
  • 18
  • 0 / 0
Так, в общем, немного поспешил. Подсмотрел в коде модуле и нашел еще одну переменную. добавил в строку &setsearchdata=1 и заработало. Может кому поможет.
Задачу решает.
Переформулирую вопрос: есть ли более изящное решение данной задачи, чтобы и ссылка покрасивее получалась, и чтобы можно было в карту сайта добавить. Например через создание пункта меню...
нашел вот как добавить новый тип меню, но это для старой версии.
http://beagler.ru/joomshopping/joomshopping-sozdaem-novyj-tip-menyu-rezultat-poiska.html
этот файл metadata.xml - пустой
Кто-то подскажет, как для JoomShopping 4.14.1 это сделать?
« Последнее редактирование: 14.07.2016, 14:45:23 от ardemish »
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
в 4.14.1 XML для пунктов меню вынесены по отдельным каталогам в папке \components\com_jshopping\views\
а еще можно создать пункт меню Поиск, а потом в базе поменять поле link для этого пункта меню в таблице #__menu
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

ardemish

  • Осваиваюсь на форуме
  • 18
  • 0 / 0
Спасибо!
Теперь не могу сообразить куда что дописать чтобы появился нужный мне тип пункта меню.
Есть папка search. Там есть tmpl/default.xml. Пытался сделать структуру по аналогии с папкой Vendors но ничего не получается.
Понимаю, что наглею, но может есть возможность расписать что и куда? Буду очень признателен  *DRINK*
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Заголовки в результатах поиска

Автор mag_num83

Ответов: 8
Просмотров: 1863
Последний ответ 12.08.2024, 10:59:03
от sivers
Получить данные пользователя из сессии или...

Автор Dewis

Ответов: 5
Просмотров: 1439
Последний ответ 27.10.2023, 02:16:39
от Dewis
Как отобразить строку поиска настраиваемого размера Joomla+JoomShopping?

Автор zantal

Ответов: 1
Просмотров: 1087
Последний ответ 19.10.2023, 18:29:32
от kit2m2
Как получить alias товара в списке товаров категории?

Автор rudoy24

Ответов: 8
Просмотров: 1083
Последний ответ 20.12.2022, 19:44:32
от rudoy24
Настройка результатов поиска JoomShopping

Автор Юрий777

Ответов: 2
Просмотров: 645
Последний ответ 17.08.2022, 09:42:12
от Юрий777