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

ljosha

  • Захожу иногда
  • 122
  • 0 / 0
Поставил компонент соц сети JomSocial и при авторизации, пользователь попадает на страницу профиля, а задача в том, чтобы он попадал на главную страницу!

Подскажите выход из ситуации!

Вот код той части сайта, где висит форма входа
Цитировать
<?php
/**
 * @package      JomSocial
 * @subpackage    Template
 * @copyright (C) 2008 by Slashes & Dots Sdn Bhd - All rights reserved!
 * @license http://www.jomsocial.com Copyrighted Commercial Software
 *
 */
defined('_JEXEC') or die();
?>
<div class="greybox">
   <div>
       <div>
         <table cellpadding="0" cellspacing="0" border="0" width="100%">
             <tr>
                 <td valign="top">
                   <div class="introduction">
                       <h1><?php echo JText::_('CC GET CONNECTED TITLE'); ?></h1>
                       <ul id="featurelist">
                           <li><?php echo JText::_('CC CONNECT AND EXPAND'); ?></li>
                           <li><?php echo JText::_('CC VEW PROFILES AND ADD FRIEND'); ?></li>
                           <li><?php echo JText::_('CC SHARE PHOTOS AND VIDEOS'); ?></li>
                           <li><?php echo JText::_('CC CREATE OWN GROUP OR JOIN'); ?></li>
                       </ul>
                       <div class="joinbutton">
                        <a id="joinButton" href="<?php echo CRoute::_( 'index.php?option=com_community&view=register' , false ); ?>" title="<?php echo JText::_('CC JOIN US NOW'); ?>">
                            <?php echo JText::_('CC JOIN US NOW'); ?>
                        </a>
                     </div>
                   </div>
                 </td>
                 <td width="200">
                   <div class="loginform">
                      <form action="<?php echo CRoute::getURI();?>" method="post" name="login" id="form-login" >
                       <h2><?php echo JText::_('CC MEMBER LOGIN'); ?></h2>
                           <label>
                           <?php echo JText::_('CC USERNAME'); ?><br />
                               <input type="text" class="inputbox frontlogin" name="username" id="username" />
                           </label>

                           <label>
                           <?php echo JText::_('CC PASSWORD'); ?><br />
                               <input type="password" class="inputbox frontlogin" name="passwd" id="password" />
                           </label>

                                <?php if(JPluginHelper::isEnabled('system', 'remember')) : ?>
                        <label for="remember">
                           <input type="checkbox" alt="<?php echo JText::_('CC REMEMBER MY DETAILS'); ?>" value="yes" id="remember" name="remember"/>
                           <?php echo JText::_('CC REMEMBER MY DETAILS'); ?>
                        </label>
                        <?php endif; ?>

                        <div style="text-align: center; padding: 10px 0 5px;">
                            <input type="submit" value="<?php echo JText::_('CC BUTTON LOGIN');?>" name="submit" id="submit" class="button" />
                           <input type="hidden" name="option" value="com_user" />
                           <input type="hidden" name="task" value="login" />
                           <input type="hidden" name="return" value="<?php echo $return; ?>" />
                           <?php echo JHTML::_( 'form.token' ); ?>
                        </div>
                       
                        <span>
                           <?php echo JText::_('CC FORGOT YOUR'); ?> <a href="<?php echo CRoute::_( 'index.php?option=com_user&view=reset' ); ?>" class="login-forgot-password"><span><?php echo JText::_('CC PASSWORD'); ?></span></a> /
                           <a href="<?php echo CRoute::_( 'index.php?option=com_user&view=remind' ); ?>" class="login-forgot-username"><span><?php echo JText::_('CC USERNAME'); ?></span></a>?
                        </span>
                        <br />                           
                        <a href="<?php echo CRoute::_( 'index.php?option=com_community&view=register&task=activation' ); ?>" class="login-forgot-username">
                           <span><?php echo JText::_('CC RESEND ACTIVATION CODE'); ?></span>
                        </a>
                       </form>
                       <?php echo $fbHtml;?>
                   </div>
                 </td>
             </tr>
         </table>
       </div>
   </div>
</div>
*

Romeo

  • Осваиваюсь на форуме
  • 45
  • 3 / 0
есть решение для модуля hellome (авторизация/редирект) тут:
http://joomlaforum.ru/index.php/topic,101707.0.html
*

ljosha

  • Захожу иногда
  • 122
  • 0 / 0
спасибо, данное решение уже видел, но мне нужно как-то настроить дефолтовый модуль авторизации
*

deacon

  • Захожу иногда
  • 57
  • 2 / 0
Не знаю как в старых версиях, а в новых можно просто выбрать, что будет открываться по умолчанию
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Настройка frontpage

Автор Raiin

Ответов: 7
Просмотров: 3549
Последний ответ 10.06.2012, 04:00:52
от sergeim