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

Vasisdas

  • Новичок
  • 5
  • 0 / 0
Добрый день!
Набрасываю небольшой плагин. Суть в том, что для запуска конкретного скрипта мне необходимо, чтобы были активны (или не активны) несколько параметров плагина.

Условие для запуска n-го скрипта, если активны 3 параметра такое:

Код
				if (($this->params->def('param1', '1'))&&($this->params->def('param2', '1'))&&($this->params->def('param3', '1'))) {

$document->addScript(JURI::base($pathonly = true). '/media/plg_blablabla/js/blablabla.js');

}
Вопрос простой: можно ли сократить эту запись?
СПАСИБО.
« Последнее редактирование: 22.12.2019, 23:25:50 от Vasisdas »
*

dmitry_stas

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

passer

  • Завсегдатай
  • 1013
  • 75 / 3
Мне одному кажется, что так всегда true будет?
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Мне одному кажется, что так всегда true будет?
Есть такое
Смущает, что если параметр не определен он будет автоматом определен как int(1)

И зачем её сокращать - в данном виде условие вполне читаемо, если правильно всё остальное )))
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

ProtectYourSite

  • Живу я здесь
  • 2368
  • 139 / 4
  • Безопасность вебсайтов
И зачем её сокращать - в данном виде условие вполне читаемо, если правильно всё остальное )))
А если одинаковых условий 10, 100 или больше ? Не думаю, что читабельно будет, тут скорее речь идёт по поиск в массиве.
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
А если одинаковых условий 10, 100 или больше ? Не думаю, что читабельно будет, тут скорее речь идёт по поиск в массиве.
Ну тогда без вопросов, 2\3 условия еще ладно, но десяток - значит у приложения неправильная логика
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Vasisdas

  • Новичок
  • 5
  • 0 / 0
Спасибо за ответы.

Да, когда я набросал несколько if для всех 3х вариантов параметров, то возникли трудности.

Чуть подробнее:
Есть 3 параметра: param1, param2, param3. Комбинации этих параметров:

все отключены (0 0 0)
1 0 0
1 1 0
1 1 1
0 1 0
0 1 1
0 0 1
1 0 1

В зависимости от выбранной комбинации запускается соответствующий скрипт.
Как правильно сформировать условие?
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Да, когда я набросал несколько if для всех 3х вариантов параметров, то возникли трудности
Значит у вас неправильная логика скрипта, что требует десяти разных условий, нужно копать глубже
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Код
$cond = $this->params->get('param1', '1'). $this->params->get('param2', '1'). $this->params->get('param3', '1');
if ($cond == '000') {
} else if ($cond == '001') {
...
}

ну или switch. или определить методы класса func000, func001 и т.д., и вызывать сразу

Код
$func = 'func'.$cond;
$this->$func()
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
ну или switch. или определить методы класса func000, func001 и т.д., и вызывать сразу
Будет тот же зоопарк, если показ элемента требует проверки 10 условий - значит изначально неправильная логика, ну не должно быть такого
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
У вас по сути - бинарные числа. Сделайте массив с этими числами (или их десятичными значениями) в качестве ключей, а сами элементы - соответствующие скрипты (ну или наоборот).
Не будь паразитом, сделай что-нибудь самостоятельно!
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
У вас по сути - бинарные числа. Сделайте массив с этими числами (или их десятичными значениями) в качестве ключей, а сами элементы - соответствующие скрипты (ну или наоборот).
Хорошая идея, тогда можно работать через case и запускать скрипт по условию.
Но опять же мы не знаем ТЗ и вообще ничего ))
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

robert

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

passer

  • Завсегдатай
  • 1013
  • 75 / 3
Понятия не имею что там в $this->params. Исхожу из того, что там json. Если ассоциированный массив то декодировать не надо.
Код
$params = json_decode($this->params,1);
$scripts = [
        000=>'script1.js',
        100=>'script2.js',
        110=>'script3.js',
        011=>'script4.js',
        001=>'script5.js',
        101=>'script6.js',
        //......
    ];
$combs = (int)$params['param1'].(int)$params['param2'].(int)$params['param3'];
$scriptByCombination = $scripts[$combs];
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Понятия не имею что там в $this->params. Исхожу из того, что там json.
А если нет (потому что там его нет)?
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

passer

  • Завсегдатай
  • 1013
  • 75 / 3
На этот случай уже подсказали.
Код
$cond = $this->params->get('param1',0). $this->params->get('param2',0). $this->params->get('param3', 0);
Логика то одна и та же. Реализация разная.
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
Есть 3 параметра: param1, param2, param3. Комбинации этих параметров:
Код
$file = 'script_'.$param1.'-'.$param2.'-'.$param3.'.js';
$document->addScript(JURI::base($pathonly = true). '/media/plg_blablabla/js/'.$file);
Разместите скрипты с именами соответствующими возможным вариантам. И все. При желании можно добавить проверку существования файла, если не для всех вариантов созданы скрипты.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Vasisdas

  • Новичок
  • 5
  • 0 / 0
Ребята, благодарю за активность.
Все варианты не пробовал, рабочим оказался вариант dmitry_stas - мне этого достаточно.

Плюсами отблагодарить не удалось - не хватает кол-ва сообщений. Поэтому просто СПАСИБО всем!

Названия топика поправил, возможно кому-то пригодится.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Плагин для сброса параметров mod_jshopping_filters

Автор robert

Ответов: 5
Просмотров: 2426
Последний ответ 24.06.2018, 16:42:31
от kr.istina7