Sobes.tech
Назад к вопросам
Senior
10

Что такое bloating в PostgreSQL и почему физический размер таблицы растёт даже после удаления данных?

Компании, где спрашивали
Позитив Технолоджис

Ответ от нейросети

sobes.tech AI

В PostgreSQL "bloating" — это ситуация, когда физический размер таблицы или индекса растёт из-за накопления «мертвых» строк (dead tuples), которые остаются после обновлений или удалений данных. PostgreSQL использует MVCC (многоверсионность), поэтому при удалении или обновлении старые версии строк не удаляются сразу, а помечаются как устаревшие.

Из-за этого физический размер таблицы не уменьшается автоматически после удаления данных. Чтобы освободить место, нужно запускать команду VACUUM, которая очищает мёртвые строки, или VACUUM FULL, которая дополнительно сжимает таблицу и возвращает место ОС.

Пример:

-- Удаляем данные
DELETE FROM my_table WHERE condition;

-- Освобождаем место
VACUUM my_table;
-- Или для более агрессивного сжатия
VACUUM FULL my_table;

Без регулярного вакуума таблица будет расти, что негативно влияет на производительность и использование диска.