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

Лена)

  • Захожу иногда
  • 402
  • 28 / 0
Сайт на 2х языках - русском и анг. На данный момент убрали кнопку переключения языков, но анг. версия сайта доступна, если в конце вместо ru написать en.
Папка images индексируется, уже несколько картинок попало в Google.image. некоторые картинки со страниц, которые ведут на анг. версию сайта.

Можно ли как-нибудь запретить индексацию или отключить анг. версию, чтобы она была недоступна?
Пробовала в JoomFish в Language Configuration снять галочку с en-GB, отключала плагин JoomFish - Missing_translation и ничего. Подскажите, что еще можно сделать
*

Lex

  • Завсегдатай
  • 1615
  • 274 / 1
robots.txt
Жизнь заставила учиться.
В личке на вопросы не отвечаю.
*

Лена)

  • Захожу иногда
  • 402
  • 28 / 0
таким образом?

Disallow: /*lang=en
*

Лена)

  • Захожу иногда
  • 402
  • 28 / 0
так если страницы попали уже в индексацию, из нее они пропадут не сразу, потребуется время. а как можно прям сейчас сделать анг. версию недоступной?
*

Виталик

  • Завсегдатай
  • 1244
  • 130 / 0
так если страницы попали уже в индексацию, из нее они пропадут не сразу, потребуется время. а как можно прям сейчас сделать анг. версию недоступной?
в .htaccess или как-то по-другому сделать перенаправление с английских страниц на соответствующие русские
*

Лена)

  • Захожу иногда
  • 402
  • 28 / 0
в .htaccess или как-то по-другому сделать перенаправление с английских страниц на соответствующие русские

.htaccess не прокатит, у меня же сайт не на платформе Unix, а на винде. там кажется web.config какой-то. а вообще, с таким перенаправлением вы встречались? 
*

Виталик

  • Завсегдатай
  • 1244
  • 130 / 0
перенаправление можно сделать на php, если в запросе есть en, то менять на ту же странице с ru
*

Лена)

  • Захожу иногда
  • 402
  • 28 / 0
да, в конце ссылок есть lang=ru или lang=en.
извините, не знаю, что вы имеете ввиду под "перенаправление можно сделать на php". а в каком файле это можно прописать?
*

Виталик

  • Завсегдатай
  • 1244
  • 130 / 0
это не совсем правильно, но добавьте в начало шаблона такой код:

if (JRequest::getVar('lang') == 'en')
{
	
$url str_replace('lang=en''lang=ru'$_SERVER['REQUEST_URI']);
	
header("Request-URI: ".$url);
	
header("Content-Location: ".$url);
	
header("Location: ".$url);
}
*

Лена)

  • Захожу иногда
  • 402
  • 28 / 0
неправильно с какой точки зрения? валидатор ругаться будет?
*

Виталик

  • Завсегдатай
  • 1244
  • 130 / 0
но работает?

идеологически неправильно делать перенаправление в шаблоне и наверное для поисковиков перед перенаправлением надо сообщать код ошибки (страница постоянно перенесена или временно)
*

Лена)

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

Лена)

  • Захожу иногда
  • 402
  • 28 / 0
это не совсем правильно, но добавьте в начало шаблона такой код:

if (JRequest::getVar('lang') == 'en')
{
	
$url str_replace('lang=en''lang=ru'$_SERVER['REQUEST_URI']);
	
header("Request-URI: ".$url);
	
header("Content-Location: ".$url);
	
header("Location: ".$url);
}


добавляла я этот код и в head и в body, во все места шаблона и ничего.  только код высвечивается на фротэнде :(
*

Lex

  • Завсегдатай
  • 1615
  • 274 / 1
 ;D Виталик не учел уровень.
Код: php
<?php
if (JRequest::getVar('lang') == 'en')
{
$url = str_replace('lang=en', 'lang=ru', $_SERVER['REQUEST_URI']);
header("Request-URI: ".$url);
header("Content-Location: ".$url);
header("Location: ".$url);
}
?>
Жизнь заставила учиться.
В личке на вопросы не отвечаю.
*

Лена)

  • Захожу иногда
  • 402
  • 28 / 0
Lex, спасибо, теперь работает!! можно было и самой догадаться этот кусочек добавить, чет с php я плохо дружу )
*

pavelm

  • Захожу иногда
  • 58
  • 0 / 0
А ещё есть версии url чистые без lang=en, lang=ru, которые тоже будут индексироваться и плодить дубли.
 
*

Лена)

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

Лена)

  • Захожу иногда
  • 402
  • 28 / 0
Кто-нибудь может напомнит, как закрыть от индексации поисковика все страницы, оканчивающиеся на lang=en (но чтобы на сайте всё осталось доступно)?
Disallow: /*lang=en
Так?
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как найти и определить сервис раскрутки сайта?

Автор Gosha5767

Ответов: 0
Просмотров: 10764
Последний ответ 08.07.2025, 17:19:50
от Gosha5767
Расширение от индексации поисковиками внешних ссылок

Автор THE KILLERS

Ответов: 6
Просмотров: 1586
Последний ответ 11.03.2022, 16:02:10
от NewUsers
Закрыть страницу со знаком? от индексации

Автор Андрей Нестеров

Ответов: 2
Просмотров: 1418
Последний ответ 28.02.2022, 22:38:44
от Андрей Нестеров
Как вывести в сниппете название статьи, а потом название сайта?

Автор gorbi_U

Ответов: 0
Просмотров: 1198
Последний ответ 18.01.2022, 18:29:22
от gorbi_U
Не дело это - закрывать от индексации страницы с пагинацией

Автор ChaosHead

Ответов: 48
Просмотров: 11648
Последний ответ 04.11.2021, 06:44:26
от Slava77