Новости 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

Перевод и публикация интервью с Joomla евангелистом на греческом портале Joomla

Перевод и публикация интервью на греческом портале Joomla 🇬🇷

Утро, просматриваешь входящие письма и изучаешь новости и внезапно обнаруживаешь, что инициатива, которую ты начал, подхватывается другими людьми. 🎉

Недавно я взял интервью у Билла (Василиса) Коциаса - руководителя студии, читающего лекции в университете и популяризатора Joomla в Греции. Это интервью из журнала NorrNext, в оригинале на английском, теперь доступно на греческом языке и опубликовано на портале joomla.gr. 🎉

До чего же приятно… 😇😊 Работа замечена и с ней посчитали необходимым ознакомить аудиторию страны, в которой Билл читает лекции. И это солнечная Греция - страна, страна, с которой Россию многое связывает. 🇬🇷🇷🇺🕊

Смотрю на греческий алфавит и тут же рисуются картины белоснежных зданий в окружении винограда и амфор, красивых женщин в сандалиях и мужественных воинов, охраняющих покой полисов, в которых ученые мужи работают над трудами, позже вошедшими в века. Красиво! 😇Но вернемся к интервью.

Из него вы узнаете, что в Греции доля Joomla среди CMS занимает порядка 30-40%. По моему мнению это - самый высокий показатель во всем мире. Также чтение лекций о Joomla в университетах позволит привести новых пользователей и к тому же молодое поколение. Ну и огромное кол-во сертификтатов Билла на стене (смотрим фото в статье) свидетельствует о том, что Joomla может применяться как профессиональный инструмент.

🌐 Оригинальное интервью (на английском)
🇬🇷 Интервью на греческом портале (joomla.gr)

Что насчет перевода на русский? Увы, времени всего 24 часа в сутках. Я продолжаю готовить новые интервью. Возможно, после завершения выпуска журнала, рассмотрю перевод некоторых интервью на русский. Но я об этом не говорил. 😊 В блоге @eugenius_blog публикую анонсы интересных событий из мира Joomla, интервью, уроки и полезные советы, а также делюсь мыслями:, связанными с разработкой и веб-дизайном.

0 Пользователей и 1 Гость просматривают эту тему.
  • 9 Ответов
  • 1023 Просмотров
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Доброго всем.

Собственно, сабж. Нужно чтобы админы никогда не входили автоматически в админку после повторного открытия браузера. Все было просто до того момента, пока некоторые (иначе не назовешь) сволочи не забили на удаление сессионных кук...

Есть у кого идеи?
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

Victor333

  • Захожу иногда
  • 445
  • 1 / 0
Может жизнь сессии сделать минимальной?
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
а есть какое-либо событие js, отлавливающие закрытие окна браузера? по событию аяксом отправлять токен сессии куда следует, а там по полученному токену сессию закрывать, не?
« Последнее редактирование: 01.05.2016, 21:07:13 от AlekVolsk »
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
а есть какое-либо событие js, отлавливающие закрытие окна браузера? по событию аяксом отправлять токен сессии куда следует, а там по полученному токену сессию закрывать, не?
Да, тоже посетила такая мысль, только на серверной стороне не закрывать сессию сразу, а сначала проверять, живо ли соединение.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Цитировать
Может жизнь сессии сделать минимальной?
Ну вот видимо да, придется делать что-то в этом направлении, иных решений не вижу. Время сессии делать минимальной не очень хочется, поскольку на сайте крутится и-магазин, и уменьшение времени сессии повлечет за собой проблемы для фронта (обнуление корзины в самый неподходящий момент, и т.п.), а туда лезть переделывать не охота. Придется видимо в админке логику менять, отслеживать время последнего обращения, и принудительно рубить сессию если больше например 70 секунд, и при этом пинговать каждые 60 секунд... Нагрузки конечно добавится, но фиг с ним для админки, придется пожертвовать...
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

dmitry_stas

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

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
имхо, поставить эксперимент: в шаблоне, в index.php добавить скрипт с вылетом алерта по событию onbeforeunload и посмотреть, в какие моменты оно срабатывает, это ж просто вроде как

а вот если это решение не подойдет, то тогда нужно будет думать дальше

если эксперимент состоится, то просьба отписаться о его результатах здесь, мож пригодится кому
« Последнее редактирование: 01.05.2016, 21:22:47 от AlekVolsk »
*

dmitry_stas

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

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
есть событие onbeforeunload и onunload, у них разное поведение, последнее срабатывает даже при переходе по ссылке с таргет=бланк, тут действительно лучше проверить
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Ну они разные, да, но основное отличие в том, что в момент onbeforeunload выгрузку страницы еще можно отменить, а в момент onunload уже нельзя. И еще плюс пару отличий, типа вызова в момент AJAX-запроса, и т.п. Но принципиальной разницы для нас нет, именно закрытие они не покажут, это будет любая выгрузка страницы.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Пропадают иконки на части страниц, пока не удалишь кеш браузера

Автор minibelka

Ответов: 4
Просмотров: 1953
Последний ответ 25.02.2024, 22:56:50
от cherianov
Получить URL из браузера на странице 404

Автор lgmax

Ответов: 0
Просмотров: 499
Последний ответ 26.06.2021, 18:04:04
от lgmax
Как вывести заголовок страницы браузера в произвольном месте через php?

Автор kiev

Ответов: 4
Просмотров: 588
Последний ответ 12.02.2021, 16:50:57
от kiev
Используйте кеш браузера

Автор Igoritaly

Ответов: 17
Просмотров: 3101
Последний ответ 21.02.2020, 07:32:42
от arma
Язык сайта в зависимости от местоположения (а не от настроек браузера)

Автор goga_pgasovav

Ответов: 22
Просмотров: 1893
Последний ответ 12.02.2020, 18:28:35
от goga_pgasovav