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

agro355

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Обрезаются "кавычки"
« : 11.04.2011, 12:29:41 »
Здравствуйте!
В компоненте фотогалереи JoomGallery при открытии (редактировании) категории или изображения в поле Название (Title) удаляються все символы начиная с обычных "кавычек" (т.е. "). А при сохранении не удаляються. Например, создаю я категорию и называю ее ТОРТ "СПАРТАК", сохраняю, все гуд - сохраняется. Теперь когда открыть данную категорию для редактирования название будет ТОРТ. Если дописать "СПАРТАК" и сохранить, то сохраниться, а если нажать Применить (Apply), то сразу исчезает.
Очень нужны именно "такие кавычки" а не какие то другие.

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

agro355

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Обрезаются "кавычки"
« Ответ #2 : 11.04.2011, 12:40:59 »
одиночные должны работать ).
''СПАРТАК'' попробуй
Спасибо, за совет, но заказчик требует "нормальных", т.е. двойных и настаивает, чтобы я сделал "как надо"...
*

al-teen

  • Глобальный модератор
  • 2385
  • 224 / 10
  • im
Re: Обрезаются "кавычки"
« Ответ #3 : 11.04.2011, 12:48:17 »
Просто экранировать их нужно.
Код
$quot = str_replace('"', '&quot', $quot);
Точнее заменить при вводе на &quot. Прямо в визуальном редакторе У Вас защита так срабатывает.
« Последнее редактирование: 11.04.2011, 12:51:52 от al-teen »
*

agro355

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Обрезаются "кавычки"
« Ответ #4 : 11.04.2011, 12:50:58 »
Просто экранировать их нужно.
Код
$quot = str_replace('"', '&quot', $quot);
Точнее заменить при выводе на &quot. У Вас защита так срабатывает
А где именно??
*

al-teen

  • Глобальный модератор
  • 2385
  • 224 / 10
  • im
Re: Обрезаются "кавычки"
« Ответ #5 : 11.04.2011, 12:54:25 »
А где именно??
Либо в Визуальном редакторе при помощи JS, либо в компоненте, который Вы используете. Точнее сказать не могу - я не Ванга, пардон
*

agro355

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Обрезаются "кавычки"
« Ответ #6 : 11.04.2011, 13:04:04 »
К сожалению, визуальный редактур тут ни причем потому, что это поле - Название (Title). Может тогда подскажете где этот код в с татьях или категория Joomla, а я уже по аналогии попытаюсь найти в компоненте JoomGallery?
*

al-teen

  • Глобальный модератор
  • 2385
  • 224 / 10
  • im
Re: Обрезаются "кавычки"
« Ответ #7 : 11.04.2011, 15:00:12 »
Как раз таки визуальный редактор еще как при чем. Вполне реально заменить на уровне ввода символ кавычек на его безопасный хтмл аналог. Но для этого нужно хотя бы на начальном уровне знать JS. И если я даже Вам напишу сам код для подмены, Вам опять же нужны знания JS чтоб его вставить. Попробуйте ту строчку, что я привел выше сперва вставить в index.php шаблона где нить сверху, чем черт не шутит, может сработает. Хотя это что называется пальцем в небо ткнуть.

Я не знаю чем Вы у себя пользуетесь, если стандартный com_content то там и ищите. Вы выполняете заказ, а не народ с данного форума. Посему и работать должны сами, а не просить поработать других за спасибо. Я указал Вам причину - экранирование кавычек. Назвал один из методов решения. Что еще нужно? Открывайте мануал и читайте, иначе не следует браться за работу, в которой ничего не умеете и не знаете.
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
Re: Обрезаются "кавычки"
« Ответ #8 : 11.04.2011, 15:21:15 »
хватит флудить )
\administrator\components\com_joomgallery\views\image\tmpl\form.php
в районе 60-ой строки приводим к следующему виду

Код
<input class="inputbox" type="text" name="imgtitle" id="title" size="40" maxlength="255" value="<?php echo $this->escape($this->item->imgtitle); ?>" />
*

agro355

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Обрезаются "кавычки"
« Ответ #9 : 11.04.2011, 16:57:52 »
Огромнейшее Вам спасибо, Effrit! Получилось! Я  и сам было нашел данную строчку кода, но вот что с ней делать не знал.

И вам, al-teen, спасибо за то что не остались равнодушным.
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
Re: Обрезаются "кавычки"
« Ответ #10 : 11.04.2011, 17:16:33 »
так надо было посомтреть аналог category, у которой название с кавычками нормально отрабатывает )
я так выловил баг
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться