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

slepoy

  • Давно я тут
  • 753
  • 24 / 0
  • Тотальная шизофазия
Здравствуйте.

Если нет возможности проводить какие-либо работы на стороне сервера, то возможно ли установить для Joomla расширение, позволяющее отследить IP конкретного пользователя после его авторизации (т.е. Не собирающий IP всех пользователей, чтобы не создавать нагрузку)?

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

Какое расширение порекомендуете?

Спасибо.
Помог? Поставь(те) плюс в репутацию.
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
*

slepoy

  • Давно я тут
  • 753
  • 24 / 0
  • Тотальная шизофазия
Да, есть пользователь, которого необходимо заблокировать по IP, дабы предотвратить возможность создания им новых аккаунтов. Я понимаю, что и такую блокировку можно обойти, но это лучше, чем ничего.

Не хотелось бы накапливать информацию об IP всех зарегистрированных пользователей.
Помог? Поставь(те) плюс в репутацию.
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
пропишите код в шаблоне на отлов юзера по id или нику, генерацию txt файла с его IP, если файла нет,
и выходом с надписью "вам тут не рады".
*

vipiusss

  • Гуру
  • 5739
  • 344 / 11
  • Скайп: renor_
<?php
  echo $_SERVER["REMOTE_ADDR"];
?>

это если автоматом IP узнать и ставить далее условие

если конкретно, то через хтесес:

order allow,deny
deny from /ip юзера/

ещё через крон можно, если таков иметься.

Если универсальное и "знать всё", то самый лучший вариант по вашему ТЗ : https://extensions.joomla.org/extension/extrawatch
Там вплоть до секунд посещения страниц в онлайне и статистики и свой крон компонента.
« Последнее редактирование: 30.12.2016, 13:51:07 от vipiusss »
Миграция, установка, обновление версий Joomla  |  Создание сайтов "под ключ"  |  Эксклюзивные заглушки "offline"  |  Работа с "напильником" над шаблонами и расширениями
*

fsv

  • Живу я здесь
  • 2782
  • 411 / 2
IP динамические у многих
Веб-разработка: заказ. Только новая разработка.
*

vipiusss

  • Гуру
  • 5739
  • 344 / 11
  • Скайп: renor_
IP динамические у многих

в кроне динамику можно ловить.
Миграция, установка, обновление версий Joomla  |  Создание сайтов "под ключ"  |  Эксклюзивные заглушки "offline"  |  Работа с "напильником" над шаблонами и расширениями
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Информация о https://all-for-joomla.ru/

Автор Preview

Ответов: 1
Просмотров: 116
Последний ответ 18.11.2025, 18:59:32
от wishlight
Компонент для Joomla 4 Менеджер Мета Тегов

Автор azm1n

Ответов: 2
Просмотров: 1198
Последний ответ 09.05.2025, 11:30:21
от azm1n
Ищу расширение 301 редиректов для Joomla 4

Автор azm1n

Ответов: 1
Просмотров: 1270
Последний ответ 04.05.2025, 22:41:05
от azm1n
Расширения для Joomla для просмотра анонимно историй в Instagram

Автор bgh97079

Ответов: 0
Просмотров: 1298
Последний ответ 24.12.2024, 19:47:43
от bgh97079
Телефонный справочник для Joomla 4

Автор kunsaid

Ответов: 2
Просмотров: 2812
Последний ответ 28.06.2023, 17:35:43
от kunsaid