Утилиты pgdump, pgdumpall, pg_restore и wal-g для резервного копирования баз данных в PostgreSQL отличаются по своим возможностям и назначению:
- pg_dump позволяет создать резервную копию одной базы данных PostgreSQL. 19 Подходит как для полного, так и для выборочного резервного копирования. 7 Позволяет гибко настраивать процесс создания дампа — от выбора формата выходного файла до уровня параллелизма при создании копии. 7
- pg_dumpall создаёт резервную копию всех баз данных внутри одного инстанса PostgreSQL. 6 Также выгружает глобальные объекты, общие для всех баз данных, такие как роли и табличные пространства. 6 Результат работы этой утилиты — SQL-скрипт, который можно использовать для восстановления всего кластера PostgreSQL на другом сервере или восстановления отдельных глобальных объектов. 9
- pgrestore предназначена для восстановления базы данных из файла резервной копии в одном из архивных форматов, который создан утилитой pgdump. 6 При наличии файлов архивов pg_restore может восстанавливать данные избирательно или даже переупорядочить объекты перед восстановлением. 6
- wal-g — утилита для PostgreSQL, с помощью которой можно создавать резервные копии WAL-файлов (непрерывных архивных журналов) и восстанавливать их. 7 Также утилита позволяет автоматически управлять хранением и очисткой устаревших WAL. 7 Достоинство wal-g — в поддержке непрерывного резервного копирования и восстановления данных. 7
Выбор между этими утилитами зависит от конкретных потребностей и целей резервного копирования.