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

leeryfox

  • Новичок
  • 5
  • 0 / 0
Всем ДД.
Есть задача:
Поле SQL. Для поля требуется пара value  text.
Я хочу вставить в материал поле SQL, которое будет выводить данные из профиля пользователя.

Зачем надо - чтобы менять только в профиле, и тогда автоматически будет меняться в документах.
Но столкнулась с тем, что в базе пишется не кириллица а юникод, пример : "\u0417\u0434\u043e\u0440\u043e\u0432".

Вставляю запрос  sql вывода данных и получаю при заполнении полей-юникод, причем если его выбрать , то тоже будет отображаться юникод (.
(SELECT profile_value  as text , user_id as value  FROM joo_user_profiles WHERE profile_key = 'profile.favoritebook')

Как решить вопрос пока не поняла. Надо чтото добавить в вывод sql ? collate не прокатывает. Если может у кого идеи ? Буду благодарна.
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
Но столкнулась с тем, что в базе пишется не кириллица а юникод, пример : "\u0417\u0434\u043e\u0440\u043e\u0432".
А страницы у вас в какой кодировке отображаются? win-1251?

Желательно, чтоб кодировка страниц совпадала с кодировкой БД. Тогда таких проблем не будет.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

leeryfox

  • Новичок
  • 5
  • 0 / 0
А страницы у вас в какой кодировке отображаются? win-1251?

Желательно, чтоб кодировка страниц совпадала с кодировкой БД. Тогда таких проблем не будет.
Страницы отображает же jooomla . Она нормально себя конвертируют  .
Т, е. Я зашла в админке в профиль пользователя, написала на русском "Здоров", в профиле отображается на русском, на сайте на русском. А вот в базе "\u0417\u0434\u043e\u0440\u043e\u0432". Делая напрямую запрос к базе в поле sql  получаю "\u0417\u0434\u043e\u0440\u043e\u0432".
Скорее всего выводит значение поля как стринг по умолчанию чтоли..картинка вывода поля в админке:
https://drive.google.com/file/d/1goPu_xIOew3WR_YDo-k8CXf6zbQjE69q/view?usp=sharing
 и что в базе имеем
https://drive.google.com/file/d/1sVUeqvsv-UapJeClc80-Sk18mLgBqpEN/view?usp=sharing
« Последнее редактирование: 28.02.2023, 12:21:45 от leeryfox »
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
какая кодировка для таблицы выбрана? как именно читаете из БД? через классы Joomla или через mysqli / pdo?
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

leeryfox

  • Новичок
  • 5
  • 0 / 0
какая кодировка для таблицы выбрана? как именно читаете из БД? через классы Joomla или через mysqli / pdo?
в базе "Сопоставление кодировки соединения: utf8_general_ci"
Читается через поле sql - запрос в первом сообщении.
Или что имеется ввиду ?
запрос в поле sqlhttps://drive.google.com/file/d/1anPPZez-U5IMa9sWifL6GfVuHgoVGCqh/view?usp=sharing
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
Посмотртел. Все нормально там. Это не уникод, а жсон.
После того, как прочитаете строку из той таблицы, надо сделать ей жсон-распаковку (не удаляя двойные кавычки):
Код

// Допустим прочитали строку из БД в $code, далее
$text = json_decode($code);
echo $text;

На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

leeryfox

  • Новичок
  • 5
  • 0 / 0
Посмотртел. Все нормально там. Это не уникод, а жсон.
После того, как прочитаете строку из той таблицы, надо сделать ей жсон-распаковку (не удаляя двойные кавычки):
Код

// Допустим прочитали строку из БД в $code, далее
$text = json_decode($code);
echo $text;

Так в поле только sql  запрос можно. И это поле потом используется отдельно в настройках материала. Там не подставить что-то другое кроме sql :(.
А Php  код разве можно вставить в Контент - материал ?
я думала только джава скрипт и HTML...
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
Так в поле только sql  запрос можно
а, ну это да. там можно вот так (пример):

Код
SELECT JSON_UNQUOTE(`profile_value`->'$') AS `text`
FROM `bl1li_user_profiles`
WHERE `profile_key` = 'profile.address1'
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
В условие выборки (WHERE) желательно поставить условие, которое будет выбирать только json-поля. иначе ошибка в запросе будет
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

leeryfox

  • Новичок
  • 5
  • 0 / 0
Все заработало! СПАСИБО! :-* :D *DRINK*
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
На здоровье
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как вывести в файле er параметры модуля?

Автор homelux

Ответов: 2
Просмотров: 269
Последний ответ 03.11.2025, 19:37:30
от fbr
Ошибка Отсутствует поле "itemReviewed

Автор Zegeberg

Ответов: 3
Просмотров: 1299
Последний ответ 24.10.2024, 12:38:24
от Zegeberg
Как вывести блог категории в материале?

Автор x1

Ответов: 0
Просмотров: 815
Последний ответ 22.10.2024, 20:11:11
от x1
Если сайт выключен как вывести сообщение и картинку?

Автор Alexs44

Ответов: 1
Просмотров: 802
Последний ответ 03.09.2024, 16:24:02
от sivers
Поле "сообщение" RSContact высотой в одну строку

Автор antipod

Ответов: 1
Просмотров: 791
Последний ответ 08.07.2024, 21:30:40
от Vastriet