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

Mouse

  • Осваиваюсь на форуме
  • 27
  • 0 / 0
Мне вот интерестно можно ли приоткрыть закрытые группу в социалке. т.е. сделать все, как в отрытой, кроме регистрации(только по инвайтам) и , предположим, оставить закрытыми обсуждения ?
*

Mouse

  • Осваиваюсь на форуме
  • 27
  • 0 / 0
Re: Приоткрыть закрытые группы
« Ответ #1 : 20.06.2010, 12:54:57 »
В крайнем случае сделать точно такую же, как и открытая, только с регистрацие по инвайтам
*

Mouse

  • Осваиваюсь на форуме
  • 27
  • 0 / 0
Re: Приоткрыть закрытые группы
« Ответ #2 : 30.08.2010, 12:16:51 »
Подойдет ли вариант, копипаста кода со странички обычной группы в закрытую ?
*

kharol

  • Moderator
  • 1721
  • 217 / 0
Re: Приоткрыть закрытые группы
« Ответ #3 : 30.08.2010, 12:44:36 »
Пытался найти свой ответ на подобную тему, но сейчас идут работы по структуризации раздела JomSocial и пока что мне сложно сориентироваться куда я переместил тему с ответом.
В двух словах:
Нельзя. Либо Вы прикрываете группу от посторонних глаз вместе с её содержимым, либо В открываете группу для всех.
Пишите исчерпывающее описание для Группы
Чтобы сказать "спасибо" достаточно нажать на "+"
Чтобы сделать бухгалтерскую проводку "спасибо" реквизиты: R192102130372, ЯД:41001768818003
*

seetvael

  • Осваиваюсь на форуме
  • 34
  • 28 / 0
Как сделать чтоб в группу можно было вступить после одобрения администратором? при этом пользователь мог бы читать сообщения в группе и просматривать учасников?
или подскажите где убрать кнопку: вступить в группу
« Последнее редактирование: 29.11.2010, 20:06:25 от seetvael »
*

seetvael

  • Осваиваюсь на форуме
  • 34
  • 28 / 0
Удалил следующий код в
components\com_community\templates\default\groups.viewgroup.php
Код
<!-- Join Group -->
 <li>
<a class="group-join" href="javascript:void(0);" onclick="javascript:joms.groups.joinWindow('<?php echo $group->id;?>');">
<?php echo JText::_('CC TAB JOIN GROUP'); ?>
</a>
</li>
<?php } ?>

<?php if( ($isAdmin) || ($isMine) || ($isMember && !$isBanned) ) { ?>

теперь могу добавлять пользователей только через админ. панель
*

seetvael

  • Осваиваюсь на форуме
  • 34
  • 28 / 0
Подскажите как переместить кнопку "вступить в группу" в модуль?
*

dremora

  • Захожу иногда
  • 461
  • 48 / 12
Цитировать
<a class="group-join" href="javascript:void(0);" onclick="javascript:joms.groups.joinWindow('<?php echo $group->id;?>');">
<?php echo JText::_('CC TAB JOIN GROUP'); ?>
</a>

Вот тут же есть... нужно только получить id группы, куда хочешь вступить... Возможно нужно взять переменную из URL.
Всё что не анархия, то фашизм...
*

seetvael

  • Осваиваюсь на форуме
  • 34
  • 28 / 0
Получилось, спасибо толь как теперь сделать чтоб модуль не отображался у участников группы
*

dremora

  • Захожу иногда
  • 461
  • 48 / 12
Получилось, спасибо толь как теперь сделать чтоб модуль не отображался у участников группы
Сделать запрос и получить $userid всех участников группы.

Потом пишем:

Код
<?PHP

$user = &JFactory::getUser();
if ($user->id == $userid) {
echo "тут ссылки нет";
}
else {
//тут, ниже пишешь свою ссылку
}

?>
« Последнее редактирование: 30.11.2010, 22:03:37 от dremora »
Всё что не анархия, то фашизм...
*

seetvael

  • Осваиваюсь на форуме
  • 34
  • 28 / 0
Как получить этот Id
Я так понял пользователей придется выбирать вручную?
*

dremora

  • Захожу иногда
  • 461
  • 48 / 12
Как получить этот Id
Я так понял пользователей придется выбирать вручную?
там скорее всего, нужно массив наверное получить... Находим группу по базе данных... id пользователеи группы помещаем в массив.

вроде как:

Код
$jsusers = array();
foreach ($rows as $row) {

//только там не id будет скорее всего поле c Joomla userid, а другое... Смотри таблицу в phpMyAdmin
$jsusers[] = $row->id;
}

Далее применяем функцию в прошлои задаче. Функция - если в массиве содержиться значение. Забыл как она там, если вспомню напишу, в общем всё старое только:
Код
$user = &JFactory::getUser();
if ($user->id == эта функция($jsusers)) {
echo "тут ссылки нет";
}
else {
//тут, ниже пишешь свою ссылку
}

« Последнее редактирование: 30.11.2010, 22:36:20 от dremora »
Всё что не анархия, то фашизм...
*

dremora

  • Захожу иногда
  • 461
  • 48 / 12
in_array() вот вспомнил... синтаксис у её:

in_array ( mixed needle, array haystack [, bool strict] )

http://www.php.su/functions/?in-array
Всё что не анархия, то фашизм...
*

dremora

  • Захожу иногда
  • 461
  • 48 / 12
Вот так будет выгладить, поправил:

Код
$user = &JFactory::getUser();
if (in_array($user->id, $jsusers)) {
echo "тут ссылки нет";
}
else {
//тут, ниже пишешь свою ссылку
}
Всё что не анархия, то фашизм...
*

kharol

  • Moderator
  • 1721
  • 217 / 0
Есть еще вариант. Может кому то пригодится на что-то.
Закрыть все группы для свободного входа, но создавая их "открытыми" (условно-открытые получается)
JomSocial 2.0.2
components/com_community/controllers/groups.php
Код
строка 2008:  $member->approved	= ( $group->approvals == COMMUNITY_PRIVATE_GROUP )? '0' : 1;
ниже добавляем:
Код
$member->approved	= ( $group->approvals == COMMUNITY_PUBLIC_GROUP )? '0' : 1;
Теперь открытые группы становятся закрытыми, но с полным просмотром.
Закрытые так и остаются сверх-закрытыми.
Останется только правильно описать статус создаваемых групп в шаблоне.
(*) В предыдущих версиях компонента, строка: 1792
« Последнее редактирование: 30.11.2010, 23:24:37 от kharol »
Чтобы сказать "спасибо" достаточно нажать на "+"
Чтобы сделать бухгалтерскую проводку "спасибо" реквизиты: R192102130372, ЯД:41001768818003
*

seetvael

  • Осваиваюсь на форуме
  • 34
  • 28 / 0
Цитировать
Есть еще вариант. Может кому то пригодится на что-то.
Закрыть все группы для свободного входа, но создавая их "открытыми" (условно-открытые получается)
JomSocial 2.0.2
Пригодилось и даже очень! именно то что икал, Огромное спасибо :D
*

dremora

  • Захожу иногда
  • 461
  • 48 / 12
Хорошо бы они(разработчики) внесли в админку это...
Всё что не анархия, то фашизм...
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться