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

jurassik

  • Давно я тут
  • 692
  • 52 / 1
meta name="og:
« : 26.01.2013, 15:22:58 »
K2 v2.6.2 Joomla 2.5.8
Код
  <meta name="og:url" content="http://сайт.ru/" />
  <meta name="og:title" content="тайтл страницы" />
  <meta name="og:type" content="Article" />
валидатор ругается,
как сильно они нужны?
« Последнее редактирование: 26.01.2013, 15:36:28 от jurassik »
сам шучу - сам смеюсь
*

jurassik

  • Давно я тут
  • 692
  • 52 / 1
Re: meta name="og:
« Ответ #1 : 26.01.2013, 15:27:59 »
Код
  <meta name="title" content="О компании" />
  <meta name="og:url" content="http://сайт.ru/kompany.html" />
  <meta name="og:title" content="О компании" />
  <meta name="og:type" content="Article" />
  <meta name="og:description" content="инфа о компании" />
  <meta name="description" content="инфа о компании" />
зачем (для кого) дублирование тайтл и описание
сам шучу - сам смеюсь
*

ELLE

  • Глобальный модератор
  • 4505
  • 893 / 0
Re: meta name="og:
« Ответ #2 : 26.01.2013, 15:32:54 »
вся инфа здесь  - http://ogp.me/
чтоб валидатор не ругался используйте HTML5
*

jurassik

  • Давно я тут
  • 692
  • 52 / 1
Re: meta name="og:
« Ответ #3 : 26.01.2013, 15:37:00 »
вся инфа здесь  - http://ogp.me/
чтоб валидатор не ругался используйте HTML5
на html5 и ругается
сам шучу - сам смеюсь
*

ELLE

  • Глобальный модератор
  • 4505
  • 893 / 0
Re: meta name="og:
« Ответ #4 : 26.01.2013, 15:56:41 »
используйте так
Код
<meta property="og:url" content="http://сайт.ru/kompany.html" /> 
валидатор будет спокоен
*

jurassik

  • Давно я тут
  • 692
  • 52 / 1
Re: meta name="og:
« Ответ #5 : 26.01.2013, 18:34:26 »
используйте так
Код
<meta property="og:url" content="http://сайт.ru/kompany.html" /> 
валидатор будет спокоен
для этой правки есть-ли какой-нибудь плагин?
ибо правка кода при обновлении затрется
сам шучу - сам смеюсь
*

ELLE

  • Глобальный модератор
  • 4505
  • 893 / 0
Re: meta name="og:
« Ответ #6 : 26.01.2013, 18:41:55 »
Сейчас каким образом вы добавляете эти данные, в таком формате?
*

jurassik

  • Давно я тут
  • 692
  • 52 / 1
Re: meta name="og:
« Ответ #7 : 26.01.2013, 18:43:47 »
их генерирует компонент к2
Код
        $document->setMetaData('og:url', $uri->toString());
        $document->setMetaData('og:title', htmlspecialchars($document->getTitle(), ENT_QUOTES, 'UTF-8'));
        $document->setMetaData('og:type', 'Article');
        $facebookImage = 'image'.$params->get('facebookImage', 'Small');
        if ($item->$facebookImage && JFile::exists(JPATH_SITE.$item->$facebookImage))
        {
            $image = substr(JURI::root(), 0, -1).str_replace(JURI::root(true), '', $item->$facebookImage);
            $document->setMetaData('og:image', $image);
            $document->setMetaData('image', $image);
        }
        $document->setMetaData('og:description', htmlspecialchars(strip_tags($document->getDescription()), ENT_QUOTES, 'UTF-8'));
сам шучу - сам смеюсь
*

ELLE

  • Глобальный модератор
  • 4505
  • 893 / 0
Re: meta name="og:
« Ответ #8 : 26.01.2013, 18:52:45 »
Я c K2 не знакома, поэтому не подскажу какие под него плагины есть.
https://extensions.joomla.org/extensions/extension-specific/k2-extensions
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

WT SEO Meta templates плагин сео-шаблонов для Joomla

Автор sergeytolkachyov

Ответов: 26
Просмотров: 5474
Последний ответ 17.10.2025, 16:00:36
от sergeytolkachyov
meta-description не отображается в Google

Автор Игарь

Ответов: 39
Просмотров: 7444
Последний ответ 20.11.2021, 18:17:12
от Byzi
В коде страницы meta name="robots" повторяется 2 раза но с разными значениями

Автор demyan

Ответов: 3
Просмотров: 1235
Последний ответ 12.10.2016, 16:32:53
от demyan
Дублированная meta open graph

Автор jennyl18

Ответов: 1
Просмотров: 1340
Последний ответ 05.11.2015, 22:02:12
от jennyl18
Установка тегов локации meta geo

Автор Ingener

Ответов: 7
Просмотров: 4044
Последний ответ 05.06.2014, 14:07:37
от Ingener