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

Starui Ded

  • Осваиваюсь на форуме
  • 31
  • 0 / 0
  • понтов.net - Ваш Новый Хостинг
Доброе время - суть проблемы такова - имеем сайт http://sded.escilon.ru/ - он посвящен онлайн игре  http://escilon.ru - нужно обеспечить регистрацию пользователей (игроков) на моем сайте чтобы ники в игре соответствовали никам на моем сайте - как это сделать? Инфа пользователя выглядит вот так http://escilon.ru/info/darkdreamer - есть мысль заставлять пользователей на время добавлять в инфу код генерируемый моим сайтом а сайт считывает инфу и проверяет код - таким образом одобряя регистрацию.
Но как это реализовать я не знаю.

Еще админы игры предложили вот это:
Часто возникает задача аутентификации пользователя при его регистрации на племенном сайте. Наиболее ее простые решения (требование прийти на специальную редкопосещаемую локацию или прописать у себя в информации оригинальный код) заставляют пользователя совершать какие-то действия, которые, очевидно, усложняют регистрацию. Мы предлагаем довольно простой метод, основанный на сравнении IP регистрируемого пользователя на сайте и IP персонажа в Эсцилоне. Очевидно, что совпадение этих IP является необходимым условием аутентификации. Будете ли вы считать его достаточным - это уже на вашей совести. Мы считаем, что вполне можно сделать такое допущение, ради значительного упрощения регистрации.
Итак, по адресу http://escilon.ru/getip/?login=ник%20перса можно получить md5-хеш IP-адреса персонажа, если он онлайн. Как и для короткой информации, ник перса в адресе регистронезависим, однако желательно указывать его правильно и urlencoded. Если указанного персонажа нет в базе данных Эсцилона, то будет выдан ответ "Can't find user with nick ник перса", если персонаж оффлайн (т.е. определить его IP невозможно), то будет выдан ответ "User ник перса is offline".

Посоветуйте пожалуйста как реализовать мою задумку - знаю что делают - не знаю как  :(
*

Starui Ded

  • Осваиваюсь на форуме
  • 31
  • 0 / 0
  • понтов.net - Ваш Новый Хостинг
Проблема решена путем переработки 1 строчки кода взятого вот отсюда http://www.logs.com.ua/?page=download&type=files - спасибо тебе огромное...
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

На сайте правая колонна ушла в низ

Автор vityavoluevich

Ответов: 3
Просмотров: 2538
Последний ответ 27.10.2023, 08:45:48
от vityavoluevich
Каков ваш заработок на сайте?возможно ли пролететь и создать не прибыльный сайт?

Автор bedalex

Ответов: 3
Просмотров: 5324
Последний ответ 05.06.2023, 11:00:40
от Ритулька88
Вход в административный раздел - Имя пользователя и пароль не совпадают

Автор ZekMan

Ответов: 70
Просмотров: 26268
Последний ответ 16.12.2017, 20:12:04
от Aleks_El_Dia
Кто логинился на сайте

Автор sosny

Ответов: 6
Просмотров: 1761
Последний ответ 24.11.2017, 10:04:41
от sosny
Не отображаются материалы и ссылки на сайте (joomla 1.5)

Автор МарияЛ

Ответов: 1
Просмотров: 1825
Последний ответ 18.03.2017, 19:22:31
от rebus