VACUUM
VACUUM — провести сборку мусора и, возможно, проанализировать базу данных
Синтаксис
VACUUM [ ( { FULL | FREEZE | VERBOSE | ANALYZE | DISABLE_PAGE_SKIPPING } [, ...] ) ] [имя_таблицы
[ (имя_столбца
[, ...] ) ] ] VACUUM [ FULL ] [ FREEZE ] [ VERBOSE ] [имя_таблицы
] VACUUM [ FULL ] [ FREEZE ] [ VERBOSE ] ANALYZE [имя_таблицы
[ (имя_столбца
[, ...] ) ] ]
Описание
VACUUM
высвобождает пространство, занимаемое «мёртвыми» кортежами. При обычных операциях Postgres Pro кортежи, удалённые или устаревшие в результате обновления, физически не удаляются из таблицы; они сохраняются в ней, пока не будет выполнена команда VACUUM
. Таким образом, периодически необходимо выполнять VACUUM
, особенно для часто изменяемых таблиц.
Без параметра команда VACUUM
обрабатывает все таблицы в текущей базе данных, которые может очистить текущий пользователь. Если в параметре передаётся имя таблицы, VACUUM
обрабатывает только эту таблицу.
VACUUM ANALYZE
выполняет очистку (VACUUM
), а затем анализ (ANALYZE
) всех указанных таблиц. Это удобная комбинация для регулярного обслуживания БД. За дополнительной информацией об анализе обратитесь к описанию ANALYZE.
Простая команда VACUUM
(без FULL
) только высвобождает пространство и делает его доступным для повторного использования. Эта форма команды может работать параллельно с обычными операциями чтения и записи таблицы, так она не требует исключительной блокировки. Однако освобождённое место не возвращается операционной системе (в большинстве случаев); оно просто остаётся доступным для размещения данных этой же таблицы. VACUUM FULL
переписывает всё содержимое таблицы в новый файл на диске, не содержащий ничего лишнего, что позволяет возвратить неиспользованное пространство операционной системе. Эта форма работает намного медленнее и запрашивает блокировку ACCESS EXCLUSIVE
для каждой обрабатываемой таблицы.
Когда список параметров заключается в скобки, параметры могут быть записаны в любом порядке. Без скобок параметры должны указываться именно в том порядке, который показан выше. Синтаксис со скобками появился в PostgreSQL 9.0; вариант записи без скобок считается устаревшим.
Параметры
FULL
Выбирает режим «полной» очистки, который может освободить больше пространства, но выполняется гораздо дольше и запрашивает исключительную блокировку таблицы. Этот режим также требует дополнительное место на диске, так как он записывает новую копию таблицы и не освобождает старую до завершения операции. Обычно это следует использовать, только когда требуется высвободить значительный объём пространства, выделенного таблице.
FREEZE
Выбирает агрессивную «заморозку» кортежей. Добавление указания
FREEZE
равносильно выполнению командыVACUUM
с параметрами vacuum_freeze_min_age и vacuum_freeze_table_age, равными нулю. Агрессивная заморозка всегда выполняется при перезаписи таблицы, поэтому в режимеFULL
это указание избыточно.VERBOSE
Выводит подробный отчёт об очистке для каждой таблицы.
ANALYZE
Обновляет статистику, которую использует планировщик для выбора наиболее эффективного способа выполнения запроса.
DISABLE_PAGE_SKIPPING
Обычно
VACUUM
пропускает страницы, учитывая карту видимости. Страницы, на которых, судя по карте, все кортежи заморожены, можно пропускать всегда, а страницы, в которых все кортежи видны всем транзакциям, могут обрабатываться только при агрессивной очистке. Более того, за исключением агрессивной очистки, некоторые страницы можно пропускать, чтобы не ждать, пока другие сеансы закончат их использовать. Этот параметр отключает пропуск страниц и рассчитан для использования только когда целостность карты видимости вызывает подозрения, что возможно при аппаратных или программных сбоях, приводящих к разрушению БД.имя_таблицы
Имя (возможно, дополненное схемой) определённой таблицы, подлежащей очистке. Если оно отсутствует, очистке подвергаются все обычные таблицы и материализованные представления в текущей базе данных. Если указанная таблица является секционированной, очищаться будут все её конечные секции.
имя_столбца
Имя столбца, подлежащего анализу. По умолчанию анализируются все столбцы. Если указан список столбцов, подразумевается операция
ANALYZE
.
Выводимая информация
С указанием VERBOSE
команда VACUUM
выдаёт сообщения о процессе очистки, отмечая текущую обрабатываемую таблицу. Также она выводит различные статистические сведения о таблицах.
Замечания
Чтобы очистить таблицу, обычно нужно быть владельцем этой таблицы или суперпользователем. Однако владельцам баз данных также разрешено сжимать все таблицы в своих базах, за исключением общих каталогов. (Ограничение в отношении общих каталогов означает, что настоящую глобальную команду VACUUM
может выполнить только суперпользователь.) VACUUM
при обработке пропускает все таблицы, на очистку которых текущий пользователь не имеет прав.
VACUUM
нельзя выполнять внутри блока транзакции.
Для таблиц с индексами GIN, VACUUM
(в любой форме) также завершает все ожидающие операции добавления в индекс, перемещая записи индекса из очереди в соответствующие места в основной структуре индекса GIN. За подробностями обратитесь к Подразделу 60.4.1.
Мы рекомендуем очищать активные производственные базы данных достаточно часто (как минимум, каждую ночь), чтобы избавляться от «мёртвых» строк. После добавления или удаления большого числа строк может быть хорошей идеей выполнить команду VACUUM ANALYZE
для каждой затронутой таблицы. При этом результаты всех последних изменений будут отражены в системных каталогах, что позволит планировщику запросов Postgres Pro принимать более эффективные решения при планировании.
Режим FULL
не рекомендуется для обычного применения, но в некоторых случаях он бывает полезен. Например, когда были удалены или изменены почти все строки таблицы, может возникнуть желание физически сжать её, чтобы освободить место на диске и ускорить сканирование этой таблицы. Чаще всего VACUUM FULL
сжимает таблицу более эффективно, чем обычный VACUUM
.
VACUUM
создаёт значительную нагрузку на подсистему ввода/вывода, что может отрицательно сказаться на производительности других активных сеансов. Поэтому иногда полезно использовать возможность задержки очистки с учётом её стоимости. За подробностями обратитесь к Подразделу 18.4.4.
Postgres Pro включает средство «автоочистки», которое позволяет автоматизировать регулярную очистку. Чтобы узнать больше об автоматической и ручной очистке, обратитесь к Разделу 23.1.
Примеры
Очистка одной таблицы onek
, проведение её анализа для оптимизатора и печать подробного отчёта о действиях операции очистки:
VACUUM (VERBOSE, ANALYZE) onek;
Совместимость
Оператор VACUUM
отсутствует в стандарте SQL.