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

Barmunk

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
index.php можно заблочить?
« : 11.05.2010, 00:53:15 »
Невозможно уже ждать когда Яндекс сделает 301 редирект с не чпу ссылок на нормальные. Прошло уже 2 месяца, только половина нормальная стала, а всего-то страниц чуть больше 100... Ктонить пробовал после чпу блочить все страницы начинающиеся с индекс.пхп? Нормально Яндекс к этому отнесется?
*

valagoff

  • Давно я тут
  • 984
  • 110 / 0
Re: index.php можно заблочить?
« Ответ #1 : 11.05.2010, 00:58:48 »
1.Проверьте действительно ли сервер отдает 301 редирект при обращении к странице по старому URL
2.Зачем блочить index, когда можно блочить строку запроса?
*

Barmunk

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: index.php можно заблочить?
« Ответ #2 : 11.05.2010, 01:27:54 »
1.Проверьте действительно ли сервер отдает 301 редирект при обращении к странице по старому URL
2.Зачем блочить index, когда можно блочить строку запроса?
Да, отдает 301 редирект, как пример: http://www.bertal.ru/index.php?url=http%3A%2F%2Ftawatec.su%2Findex.php%3Fpage%3Dshop.product_details%26category_id%3D19%26flypage%3Dflypage.tpl%26product_id%3D60%26option%3Dcom_virtuemart%26Itemid%3D71&ar=94615#h
Тайтл в выдаче еще не сменен, урл не преобразован... Просто уже не возможно столько ждать...

Всмысле строку запроса? Объясните пожалуйста.
*

valagoff

  • Давно я тут
  • 984
  • 110 / 0
Re: index.php можно заблочить?
« Ответ #3 : 11.05.2010, 01:49:07 »
Всмысле строку запроса? Объясните пожалуйста.
в файле robots.txt
Код
Disallow: /*?*
*

Barmunk

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: index.php можно заблочить?
« Ответ #4 : 11.05.2010, 02:12:34 »
в файле robots.txt
Код
Disallow: /*?*
Отлично! Спасибо!
*

Barmunk

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: index.php можно заблочить?
« Ответ #5 : 12.05.2010, 01:30:38 »
Еще один вопросик...

Есть на сайте вложения папок вида:
 
1. Компоненты
1.2 Плагин1
1.3 Плагин2
1.4 Плагин3
1.5 Плагин4
 
Мне нужно чтобы из всех папок индексировалось только плагин2, остальные были заблокированы роботс.
 
Какой из вариантов правильный? или не какой?
 
User-agent: *
Disallow: /компоненты/Плагин1/
Disallow: /компоненты/плагин3/
Disallow: /компоненты/плагин4/
Тоесть просто перечислить все те папки которые нужно заблочить, кроме той, которая нужна.
Минус этого что придется делать в дальнейшем огромный список того что надо заблочить...
 
User-agent: *
Disallow: /компоненты/
Allow: /компоненты/плагин2/
Правильно ли так будет?
*

Haz86

  • Новичок
  • 4
  • 0 / 0
Re: index.php можно заблочить?
« Ответ #6 : 03.06.2010, 17:00:58 »
Вопрос такой:
В выдаче яндекса выходит дубль главной страницы - сайт.ру/index.php
Каким образом лучше исключить эту страницу из индекса? В роботс.тхт прописать:
User-agent: *
Disallow: /index.php

Или есть какой-то другой способ?
И не выкинет ли Яндекс из индекса другие страницы типа:
/index.php?option=com_content&task=blogsection&id=2&Itemid=11
*

Darkick

  • Завсегдатай
  • 1142
  • 239 / 1
Re: index.php можно заблочить?
« Ответ #7 : 03.06.2010, 20:01:57 »
И не выкинет ли Яндекс из индекса другие страницы типа:
/index.php?option=com_content&task=blogsection&id=2&Itemid=11
выкинет.
я руками сделал модификацию, чтобы с чистого index.php редиректило в корень.
Код: php
if (!$_POST && ($_SERVER['REQUEST_URI'] == '/index.php')) {
header('Location: http://'.$_SERVER['SERVER_NAME'].'/', true, 301);
die();
}
добавить в начало index.php


...
Какой из вариантов правильный? или не какой?
...
первый. директивы Allow нет.
*

Haz86

  • Новичок
  • 4
  • 0 / 0
Re: index.php можно заблочить?
« Ответ #8 : 04.06.2010, 13:02:00 »
Darkick, спасибо! :D  Помогло! Осталось посмотреть как Яндекс отнесется к этому  ^-^
*

style.ilya

  • Осваиваюсь на форуме
  • 49
  • 0 / 0
  • http://dreambikes.ru
Re: index.php можно заблочить?
« Ответ #9 : 30.06.2010, 00:18:28 »

я руками сделал модификацию, чтобы с чистого index.php редиректило в корень.
Код: php
if (!$_POST && ($_SERVER['REQUEST_URI'] == '/index.php')) {
header('Location: http://'.$_SERVER['SERVER_NAME'].'/', true, 301);
die();
}
добавить в начало index.php

Спасибо. Все работает. До этого я прописывал такие строки в .htaccess:

Код
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /index\.php\ HTTP/
RewriteRule ^index\.php$ http://сайт.ru/ [R=301,L]

И после этого при нажатии кнопки купить в VirtueMart показывалась просто белая страница.

Вообще, это важная вещь, редирект с index.php на корень сайта ?
*

Webb

  • Захожу иногда
  • 304
  • 19 / 2
  • rusinmd
Re: index.php можно заблочить?
« Ответ #10 : 01.07.2010, 02:16:11 »


Вообще, это важная вещь, редирект с index.php на корень сайта ?

вам нужны дубли?
*

rubasket

  • Захожу иногда
  • 346
  • 13 / 1
  • RuBasket.com
Re: index.php можно заблочить?
« Ответ #11 : 01.07.2010, 06:40:09 »
в файле robots.txt
Код
Disallow: /*?*
таким макаром ты все компоненты ,не имеющие роута, заблокируешь
Только я знаю,что могу (C) Джон Локк 
Why him ?Mmm? What  about me? БЕНЖАМИН Л
*

style.ilya

  • Осваиваюсь на форуме
  • 49
  • 0 / 0
  • http://dreambikes.ru
Re: index.php можно заблочить?
« Ответ #12 : 01.07.2010, 13:36:49 »
вам нужны дубли?

Да хрен его знает ) я только недавно узнал что сайт с www и без поисковики могут считать как два.

P.S. сегодня Яндекс Метрика пишет, что код счетчика установлен не на всех страницах. Хм..это может быть связяно с тем, что я ввел это правило с Index.php? Правда сама метрика глючит..пишет ошибку..
*

whois

  • Осваиваюсь на форуме
  • 18
  • 1 / 0
Re: index.php можно заблочить?
« Ответ #13 : 03.08.2010, 14:57:03 »

Какой из вариантов правильный? или не какой?
 
User-agent: *
Disallow: /компоненты/Плагин1/
Disallow: /компоненты/плагин3/
Disallow: /компоненты/плагин4/
Тоесть просто перечислить все те папки которые нужно заблочить, кроме той, которая нужна.
Минус этого что придется делать в дальнейшем огромный список того что надо заблочить...
 
User-agent: *
Disallow: /компоненты/
Allow: /компоненты/плагин2/
Правильно ли так будет?
первый. директивы  нет.

Директива Allow есть! Читаем внимательно! http://help.yandex.ru/webmaster/?id=996567#996571 Только надо писать ее перед Disallow

User-agent: *
Allow: /компоненты/плагин2/
Disallow: /компоненты/
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Htaccess и редирект с index.php на без index.php

Автор PavelK

Ответов: 2
Просмотров: 4684
Последний ответ 11.05.2023, 14:31:40
от PaLyCH
Каким плагином можно закрыть внешние ссылки?

Автор gorbi_U

Ответов: 4
Просмотров: 2923
Последний ответ 25.02.2023, 02:29:35
от olegon
Можно ли скрывать SEO текст?

Автор kiev

Ответов: 16
Просмотров: 2552
Последний ответ 13.08.2020, 11:59:57
от zikkuratvk
/index.php?option=com.... как закрыть от индексации подобные страницы?

Автор roma_sanbl4

Ответов: 2
Просмотров: 1437
Последний ответ 20.09.2017, 10:33:53
от roma_sanbl4
Пустым или не пустым должен быть index.html в папке шаблона?

Автор borro

Ответов: 1
Просмотров: 1131
Последний ответ 07.03.2017, 14:18:31
от effrit