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

stepan39

  • Захожу иногда
  • 499
  • 28 / 0
Добрый день!

Прошу поделиться опытом отслеживания конверсий (регистрация нового юзера) при стандартной регистрации Joomla и через Slogin. Загвоздка собственно не в размещении самого кода Метрики или Аналитикса (хотя и тут есть вопросы  ^-^), а в его правильной работоспособности. Если просто повесить этот код на события с нужными кнопками (Регистрация или иконки в Slogin), то эти события не смогут правильно отследить конверсию. Например, в форме регистрации юзер может сколько угодно тыкнуть "Регистрация", вводя некорректные данные (почту к примеру или пропуская поля), а в Slogin нажать на иконку соцсети, а дальше не пойти.

Более узко: для регистрации используются Improved AJAX Login and Register без активации и с автологином + Slogin без редактирования данных перед регистрацией (т.е. автоматическая регистрация при входе через соцсети).

Заранее спасибо!

UPDATE: При обычной регистрации рассматривал редирект на служебную страницу (ее посещения как-раз очень легко отслеживать) с последующим редиректом через 5 секунд куда надо. Так вот "куда надо" как раз не получается - необходим возврат на страницу, с которой шла регистрация (форма в попапе, может быть на любой странице).
 
« Последнее редактирование: 13.10.2017, 11:49:28 от stepan39 »
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
нужен плагин, который поймает событие успешной регистрации Joomla, и только после этого выведет код отправки данных в метрику/аналитику
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

SmokerMan

  • Гуру
  • 5290
  • 720 / 26
ну есть же наверно какая-то страница после регистрации, вот на ней и можно сделать
*

stepan39

  • Захожу иногда
  • 499
  • 28 / 0
ну есть же наверно какая-то страница после регистрации, вот на ней и можно сделать
В топике почти сразу добавил решение через такой вариант. Но там трудность в возврате на предыдущую страницу. Условно я нахожусь на странице определенного товара, форма регистрация в попапе, жму регистрация - попадаю на служебную (есть конверсия!), а вот дальше... Как со служебной уйти опять на страницу товара? Из известных мне вариантов редиректа знаю только как на определенную страницу отправить юзера.
Код
<meta http-equiv="Refresh" content="90; url=/" />
« Последнее редактирование: 13.10.2017, 12:40:51 от stepan39 »
*

stepan39

  • Захожу иногда
  • 499
  • 28 / 0
нужен плагин, который поймает событие успешной регистрации Joomla, и только после этого выведет код отправки данных в метрику/аналитику
Возможно, но про готовые решения я не слышал. Хочется пока все подручными средствами решить.
*

SmokerMan

  • Гуру
  • 5290
  • 720 / 26
В топике почти сразу добавил решение через такой вариант. Но там трудность в возврате на предыдущую страницу. Условно я нахожусь на странице определенного товара, форма регистрация в попапе, жму регистрация - попадаю на служебную (есть конверсия!), а вот дальше... Как со служебной уйти опять на страницу товара? Из известных мне вариантов редиректа знаю только как на определенную страницу отправить юзера.
ну если конкретной страницы нету можно попробовать отследить через $_SERVER['HTTP_REFERER']
тут сложно чего-то сказать, т.к. установлено много чего и хз как оно все там работает

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

stepan39

  • Захожу иногда
  • 499
  • 28 / 0
в принципе там плагин очень простой
Я, к огромному сожалению, не разработчик. На сколько денег потянет "простой" плагин? Реализация и ТЗ фактически изложены выше.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться