Перейти к контенту
  • 0

Что за временная таблица?


AlfOz

Вопрос

Последнее время стал тормозить форум. Причем не постоянно, а периодами, при этом нагружая сервер до беспредела.

Долго искал причину, и вдруг обнаружил, что это происходит из-за того что в эти моменты mysql начинает создавать в tmp какую то странную таблицу, по формату и размеру похожую на ibf_posts. Естественно, забивается кэш и идут тормоза. Потом он ее удаляет и все опять идет нормально.

Никто не подскажет, что это за временная таблица?

Ссылка на комментарий
Поделиться на других сайтах

Рекомендуемые сообщения

  • 0

Админцентр: Средства mySQL => ibf_posts => оптимизировать.

 

Индекст к таблице сообщений весит примерно столько же, сколько сама таблица, лучше его хотя бы раз в неделю вручную оптимизировать.

Ссылка на комментарий
Поделиться на других сайтах

  • 0

2AlfOz

 

Вероятно это из-за сложных запросов.

Когда выполняется сложный джойн MySQL создаёт временную таблицу для объединения результатов выборки (сам join собственно).

Ссылка на комментарий
Поделиться на других сайтах

  • 0
А надо делать как советует FatCat? Ничего плохого с таблицей постов не случится?
Ссылка на комментарий
Поделиться на других сайтах

  • 0

А вы знаете, ситуация оказалась в следующем. В Boards.php обрабатывается такой запрос:

$DB->query("SELECT COUNT(DISTINCT(p.pid)) as posts, COUNT(DISTINCT(p.topic_id)) as topics FROM ibf_posts p WHERE p.post_date > '".$ibforums->member['last_visit']."' AND queued <> 1 AND forum_id IN($forum_string)");

Переписал его на два запроса:

$DB->query("SELECT COUNT(DISTINCT(p.pid)) as posts FROM ibf_posts p WHERE p.post_date > '".$ibforums->member['last_visit']."' AND queued <> 1 AND forum_id IN($forum_string)");
$DB->query("SELECT COUNT(DISTINCT(p.topic_id)) as topics FROM ibf_posts p WHERE p.post_date > '".$ibforums->member['last_visit']."' AND queued <> 1 AND forum_id IN($forum_string)");

И тормоза прекратились. :D

Ссылка на комментарий
Поделиться на других сайтах

Присоединиться к обсуждению

Вы можете ответить сейчас, а зарегистрироваться позже. Если у вас уже есть аккаунт, войдите, чтобы ответить от своего имени.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить на вопрос...

×   Вы вставили отформатированный текст.   Удалить форматирование

  Допустимо не более 75 смайлов.

×   Ваша ссылка была автоматически заменена на медиа-контент.   Отображать как ссылку

×   Ваши публикации восстановлены.   Очистить редактор

×   Вы не можете вставить изображения напрямую. Загрузите или вставьте изображения по ссылке.

Зарузка...
×
×
  • Создать...

Важная информация

Находясь на нашем сайте, вы соглашаетесь на использование файлов cookie, а также с нашим положением о конфиденциальности Политика конфиденциальности и пользовательским соглашением Условия использования.