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

katjuha6

  • Захожу иногда
  • 173
  • 0 / 0
Всем доброго дня (вечера, ночи)! =)
Уважаемые форумчане, поделитесь, пожалуйста, знаниями на тему того, как можно скрыть модуль в определенной категории VirtueMart.
прошу простить, если задаю вопрос, который уже был где-то здесь раскрыт - я не нашла...
буду очень признательна за помощь =)
*

fsv

  • Moderator
  • 2782
  • 411 / 2
как можно скрыть модуль в определенной категории VirtueMart.
Самое примитивное - оберните код модуля (кроме первой строки проверки на доступ) условием
if ( $_GET[category_id] != XX || $_GET[category_id] != YY ) {
   //код модуля
}
Веб-разработка: заказ. Только новая разработка.
*

katjuha6

  • Захожу иногда
  • 173
  • 0 / 0
спасибо большое за ответ, только немного не поняла.
у меня есть позиция "right", в которой выводится несколько модулей.
в принципе можно в правой колонке тогда сделать несколько позиций:
card (корзина)
filter (фильтрация товаров) - вот ее и не надо выводить, соответственно обернуть в этот код
right - все остальные модули.
или Ваш способ можно как-то более изящно применить?
« Последнее редактирование: 16.03.2013, 16:27:14 от katjuha6 »
*

fsv

  • Moderator
  • 2782
  • 411 / 2
спасибо большое за ответ, только немного не поняла.
у меня есть позиция "right", в которой выводится несколько модулей.
в принципе можно в правой колонке тогда сделать несколько позиций:
card (корзина)
filter (фильтрация товаров) - вот ее и не надо выводить, соответственно обернуть в этот код
right - все остальные модули.
или Ваш способ можно как-то более изящно применить?
Я не о позициях модуля в шаблоне, а о самом модуле, его коде. Если при выводе модулей нет всяких "шапок", должно хватить. Иначе, сделайте для этого модуля свою позицию в шаблоне и позицию выводите по условию. Например,
Код
<?php
$option = JRequest::getVar('option', null);
$page = JRequest::getVar('page', null);
 if ( $option == "com_virtuemart" && $page == "shop.browse" ) {
            if ($_GET[category_id] != XX) { ?>
   <jdoc:include type="modules" name="right_vm" style="user" />
<?php }
} ?>

Веб-разработка: заказ. Только новая разработка.
*

katjuha6

  • Захожу иногда
  • 173
  • 0 / 0
благодарю Вас! сейчас попробую)))
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Цитировать
или Ваш способ можно как-то более изящно применить?
Отправить в вредные советы  :laugh:
fsv забыл про JRequest
Код: php-brief
<?php
$you_category = array(407,5,6,7,3,2,1,257);//Список категорий в котрых не показывать
$option = JRequest::getCmd( 'option', '' );
$category_id = JRequest::getInt('category_id', 0 );
if($option == 'com_virtuemart' && $category_id != 0 && !in_array($category_id, $you_category)): ?>
<jdoc:include type="modules" name="my" />
<?php endif; ?>
*

katjuha6

  • Захожу иногда
  • 173
  • 0 / 0
и Вам, Федор, спасибо! щас оба способа буду пробовать! =)
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Это наверное будет полное решение. С учетом того что модуль не будет отображаться на страницах товаров этих категорий.
Код: php-brief
<?php
$you_category = array(407,5,6,7,3,2,1,257);//Список категорий в котрых не показывать
$view_module = true;
$option = JRequest::getCmd( 'option', '' );
$category_id = JRequest::getInt('category_id', 0 );
$product_id = JRequest::getInt('product_id', 0 );
if($option == 'com_virtuemart')
{
if ($category_id == 0 && $product_id != 0)
{
$db =& JFactory::getDBO();
$sql="SELECT category_id FROM #__vm_product_category_xref WHERE product_id={$product_id}";
$db->setQuery( $sql );
$category_id = $db->loadResult('category_id');
}
$view_module =!in_array($category_id, $you_category);
}
if ($view_module): ?>
<jdoc:include type="modules" name="my" />
<?php endif; ?>
*

fsv

  • Moderator
  • 2782
  • 411 / 2
Для того, чтобы модуль не отображался на страницах товаров этих категорий, согласен, что из условия надо исключить проверку на $page, оставив только на $option. Учитывая, что на странице товара в урле присутствует category_id, все остальное - лишнее.

Код
if ($category_id == 0)
{
$db =& JFactory::getDBO();
$sql="SELECT category_id FROM #__vm_product_category_xref WHERE product_id={$product_id}";
$db->setQuery( $sql );
$category_id = $db->loadResult('category_id');
}
Если $category_id == 0 , то и $product_id вряд ли там найдется. О чем запрос?
Веб-разработка: заказ. Только новая разработка.
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Цитировать
Если $category_id == 0 , то и $product_id вряд ли там найдется. О чем запрос?
Я привел решение из одной из выполненный работ. К сожалению, в url товара там отсутствовал category_id
Потому и пришлось писать запрос. Если в товаре присутствует category_id то решение первый вариант иначе 2
*

fsv

  • Moderator
  • 2782
  • 411 / 2
Я привел решение из одной из выполненный работ. К сожалению, в url товара там отсутствовал category_id
Потому и пришлось писать запрос. Если в товаре присутствует category_id то решение первый вариант иначе 2

Тогда позвольте дополнить:
if ($category_id == 0 && isset($product_id))

Иначе будут сообщения на страницах НЕкатегорий VM.
« Последнее редактирование: 16.03.2013, 17:46:30 от fsv »
Веб-разработка: заказ. Только новая разработка.
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Цитировать
Тогда позвольте дополнить:
if ($category_id == 0 && isset($product_id))
$product_id =0;
isset($product_id) вернет true
if ($category_id == 0 && $product_id !=0)
*

katjuha6

  • Захожу иногда
  • 173
  • 0 / 0
битва титанов....
уважаемые юноши, я очень прошу прощения, но я окончательно запуталась. что все таки писать, для меня php пока слабо понятен и сама я вряд ли разберусь.
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Попробуйте для начала
Код: php-brief
<?php
$you_category = array(407,5,6,7,3,2,1,257);//Список категорий в котрых не показывать
$option = JRequest::getCmd( 'option', '' );
$category_id = JRequest::getInt('category_id', 0 );
if($option == 'com_virtuemart' && $category_id != 0 && !in_array($category_id, $you_category)): ?>
Здесь вывод позиции модуля и ли самого модуля к примеру
<jdoc:include type="modules" name="mypositions" />
<?php endif; ?>
*

fsv

  • Moderator
  • 2782
  • 411 / 2
$product_id =0;
isset($product_id) вернет true
if ($category_id == 0 && $product_id !=0)

При ответе строку
Код
$product_id = JRequest::getInt('product_id', 0 );
вообще не учитывал, считая ее лишней. Но так как она нужна для вашего запроса, то если с ней, да, будет true.

Кстати, в какой ситуации  нет category_id , но есть product_id ?
Веб-разработка: заказ. Только новая разработка.
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Цитировать
Кстати, в какой ситуации  нет category_id , но есть product_id
Это уже не вспомнить.  ^-^ Но пришлось как вы видите извращаться.
По id продута с помощью запроса получать номер категории.
*

katjuha6

  • Захожу иногда
  • 173
  • 0 / 0
Ребята, ваш спор я все равно не поняла, но работают оба варианта.  ;)
спасибо вам огромное (просто огромнейшее) за помощь!
*

sept

  • Захожу иногда
  • 60
  • 5 / 1
  • J2.5.6+VM2.0.6
Ребят, можете разжевать еще раз, пожалуйста.

У меня модуль, выводит слайдшоу в position-2. Нужно чтобы он отображался только на главной странице, НО не в категориях.

Код index.php моего шаблона:
Код
Извините, код удален.

Я так понимаю, нужно менять код после <div class="breadcrumbs-pad">, но сколько пробовал, все время ошибка вываливается.  !
« Последнее редактирование: 14.01.2014, 19:29:37 от sept »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Альтернативный модуль вывода категорий товаров (mod_kdz_vm_categories)

Автор kordima

Ответов: 89
Просмотров: 29313
Последний ответ 19.02.2015, 22:02:14
от kordima
Вывод производителя не как ссылка

Автор StivinKing

Ответов: 1
Просмотров: 1536
Последний ответ 12.11.2014, 03:34:56
от evgen777
Показ модуля на странице товара только

Автор EmAl

Ответов: 24
Просмотров: 4153
Последний ответ 27.05.2014, 08:15:01
от Mitriy-Bug
Карусель категорий на Jquery! Сделал модуль, помогите собрать!

Автор Stems

Ответов: 2
Просмотров: 3774
Последний ответ 24.12.2013, 16:42:28
от KARATIST
VM 1.3 количество категорий на странице?

Автор Myst

Ответов: 24
Просмотров: 15155
Последний ответ 19.12.2013, 13:35:32
от itazura