pg_basebackup
pg_basebackup — создать резервную копию кластера Postgres Pro
Синтаксис
pg_basebackup
[параметр
...]
Описание
pg_basebackup предназначен для создания резервных копий работающего кластера баз данных Postgres Pro. Процедура создания копии не влияет на работу других клиентов. Полученные копии могут использоваться для обеих стратегий восстановления — на заданный момент в прошлом (см. Раздел 24.3) и в качестве отправной точки для ведомого сервера при реализации трансляции файлов или потоковой репликации (см. Раздел 25.2).
pg_basebackup создаёт бинарную копию файлов кластера, контролируя режим создания копии автоматически. Резервные копии всегда создаются для кластера целиком и невозможно создать копию для какой-либо сущности базы отдельно. Для этой цели можно использовать, например, утилиту pg_dump.
Копия создаётся через обычное подключение к Postgres Pro, и при этом используется протокол репликации. Подключение должно осуществляться от лица суперпользователя или пользователя с правом REPLICATION
(см. Раздел 20.2), а в pg_hba.conf
должно быть прописано подключение для репликации. Значение max_wal_senders на сервере должно быть достаточно большим, чтобы допускать минимум ещё одно подключение для копирования и одно для трансляции WAL (если она используется).
Можно запустить одновременно несколько команд pg_basebackup
, но с точки зрения производительности лучше делать всего одну копию одновременно, а затем копировать получаемый результат.
С помощью pg_basebackup можно получить базовую копию не только на ведущем, но и на ведомом сервере. Для этого на ведомом сервере необходимо разрешить соединения репликации (параметры max_wal_senders
и hot_standby, а также настроить аутентификацию компьютера). При этом на ведущем необходимо включить full_page_writes.
Заметьте, что при копировании с ведомого сервера есть некоторые ограничения:
Файл истории резервного копирования в целевом кластере баз данных не создаётся.
pg_basebackup не может принудительно переключить ведомый сервер на новый файл WAL в конце копирования. Поэтому, если используется режим
-X none
и активность записи на ведущем сервере низкая, pg_basebackup может довольно долго ждать переключения и архивирования последнего файла WAL, необходимого для полноты копии. В этом случае может иметь смысл выполнить на ведущем сервереpg_switch_wal
для немедленного переключения файла WAL.Если ведомый сервер переключается в роль ведущего в процессе копирования, копирование прерывается.
Все необходимые для резервной копии WAL-записи должны содержать полные страницы, для чего нужно включить режим
full_page_writes
на ведущем и не использовать вarchive_command
такие утилиты, как pg_compresslog, которые могут удалить записанные полные страницы из WAL.
Параметры
Описанные далее аргументы командной строки влияют на размещение и формат вывода.
-D
каталог
--pgdata=
каталог
Целевой каталог для записи данных. pg_basebackup создаст его и родительские, если необходимо. Каталог может быть создан заранее, но должен быть пустым, иначе возникнет ошибка.
Если резервирование работает в режиме
tar
, а имя каталога имеет значение-
(тире), то tar-файл будет писаться вstdout
.Этот флаг является обязательным.
-F
формат
--format=
формат
Устанавливает формат вывода.
формат
может принимать следующие значения:p
plain
Записывает выводимые данные в обычные файлы, сохраняя структуру текущих каталогов данных и табличных пространств. Если в кластере нет дополнительных табличных пространств, вся база будет помещена в заданный каталог. Иначе основной каталог хранения данных будет помещён в целевой каталог, а все остальные табличные пространства — в те же абсолютные пути, в которых они располагаются на исходном сервере. (Чтобы изменить эти пути, воспользуйтесь параметром
--tablespace-mapping
).Это формат по умолчанию.
t
tar
Записывает в целевой каталог файлы в формате tar. Основной каталог хранения данных будет писаться в файл
base.tar
, а табличные пространства — в файлы, именованные в соответствии с их OID.Если имя целевого каталога задано как
-
(тире), то данные будут писаться в стандартный вывод, что позволяет, например, использовать gzip. Это возможно лишь когда не применяются дополнительные табличные пространства и не используется трансляция WAL.
-r
скорость_передачи
--max-rate=
скорость_передачи
Максимальная скорость передачи данных с сервера. Значение задаётся в Кб/с. Для установки значения в мегабайтах, можно использовать суффикс
M
. Также допустим суффиксk
, но он не принципиален. Допустимые значения лежат в рамках между 32 Кб/с и 1024 Мб/с.Служит для снижения влияния на производительность сервера со стороны работающего pg_basebackup.
Этот параметр всегда оказывает влияние на передачу каталога данных, а на передачу файлов WAL он влияет, только если выбран метод передачи
fetch
.-R
--write-recovery-conf
Записать минимальный файл
recovery.conf
в каталог вывода (или базовый архивный файл при использовании формата tar) для упрощения настройки ведомого сервера. В файлrecovery.conf
будут записаны параметры соединения и, если указан, слот репликации, который использует pg_basebackup, так что впоследствии при потоковой репликации будут использоваться те же параметры.-S
имя_слота
--slot=
имя_слота
Этот параметр может применяться только вместе с
-X stream
. Он устанавливает использование заданного слота репликации при потоковой передаче WAL. Если базовая копия предназначена для использования на ведомом сервере с потоковой репликацией, затем должен использоваться слот с тем же именем вrecovery.conf
. Тем самым гарантируется, что сервер не удалит никакие необходимые данные WAL после того, как базовая копия будет получена, и до того, как начнётся потоковая репликация.Если этот ключ не указан и сервер поддерживает временные слоты репликации (они появились в версии 10), для трансляции WAL автоматически используется временный слот репликации.
--no-slot
Этот ключ предотвращает создание временного слота репликации во время резервного копирования, даже если это поддерживается сервером.
Временные слоты репликации создаются по умолчанию, если при трансляции журнала имя слота не задаётся в параметре
-S
.Основное предназначение этого ключа в том, чтобы можно было сделать базовую резервную копию, когда на сервере не хватает свободных слотов репликации. Использование слотов репликации почти всегда предпочтительнее, так как при этом предотвращается удаление во время резервного копирования необходимых файлов WAL с сервера.
-T
старый_каталог
=новый_каталог
--tablespace-mapping=
старый_каталог
=новый_каталог
Переместить табличное пространство из
старого_каталога
вновый_каталог
в процессе копирования. Чтобы перемещение произошло, в параметрестарый_каталог
должен задаваться в точности путь табличного пространства, как он определён. (Но не будет ошибкой, если табличного пространства, на которое указываетстарый_каталог
, в архиве не окажется.) Истарый_каталог
, иновый_каталог
должны задаваться абсолютными путями. Если в пути встречается символ=
, его необходимо экранировать обратной косой чертой. Этот параметр можно добавить несколько раз для нескольких табличных пространств. См. примеры ниже.Если табличное пространство перемещается таким способом, символические ссылки внутри основного каталога хранения данных также приводятся в соответствие с новым местоположением. Таким образом, для экземпляра сервера подготавливается новый каталог данных, в котором все табличные пространства оказываются в новом расположении.
В настоящее время этот параметр работает только с обычным форматом вывода; если выбран формат tar, параметр игнорируется.
--waldir=
каталог_wal
Указывает размещение каталога хранения журнала предзаписи. Задаваемый в параметре
каталог_wal
путь должен быть абсолютным. Каталог с журналом предзаписи можно задать только при создании копии в простом режиме.-X
метод
--wal-method=
метод
Включает все необходимые файлы журналов предзаписи (файлы WAL) в резервную копию. В том числе включаются все журналы предзаписи, сгенерированные в процессе создания резервной копии. Если только не выбран метод
none
, главный процесс БД может быть запущен непосредственно с восстановленным каталогом, без обращения к дополнительному архиву журналов; таким образом будет получена полностью самодостаточная резервная копия.Для сбора журналов предзаписи поддерживаются следующие методы:
n
none
Не включать журнал предзаписи в резервную копию.
f
fetch
Файлы журнала предзаписи собираются в конце процесса копирования. Таким образом необходимо установить достаточно большое значение параметра wal_keep_segments, чтобы избежать преждевременного удаления файлов журнала. В случае удаления файлов до завершения процесса копирования возникнет ошибка, а копия будет непригодной к использованию.
Когда используется формат tar, файлы журнала предзаписи записываются в файл
base.tar
.s
stream
Передавать журнал предзаписи в процессе создания резервной копии. При этом открывается второе соединение к серверу, по которому будет передаваться журнал предзаписи, одновременно с созданием резервной копии. Таким образом будут использоваться два подключения из разрешённых параметром max_wal_senders. И если клиент будет успевать получать журнал предзаписи, ведущему серверу не потребуется хранить дополнительные файлы журнала.
Когда используется формат tar, файлы журнала предзаписи сохраняются в отдельном файле с именем
pg_wal.tar
(если версия сервера ниже 10, файл будет называтьсяpg_xlog.tar
).Это значение по умолчанию.
-z
--gzip
Включает gzip-сжатие выводимого tar-файла с уровнем компрессии по умолчанию. Сжатие поддерживается только для формата tar, при этом ко всем именам файлов tar добавляется суффикс
.gz
.-Z
уровень
--compress=
уровень
Включает gzip-сжатие выводимого tar-файла и задаёт уровень сжатия от 0 (без сжатия) до 9 (максимальное сжатие). Сжатие поддерживается только для формата tar, при этом ко всем именам файлов tar добавляется суффикс
.gz
.
Описанные далее аргументы командной строки влияют на генерацию резервной копии и ход выполнения приложения.
-c
fast|spread
--checkpoint=
fast|spread
Устанавливает режим контрольных точек: fast (быстрый) или spread (протяжённый, по умолчанию). Подробнее см. Подраздел 24.3.3.
-l
метка
--label=
метка
Устанавливает метку для созданной резервной копии. Если не указана, то по умолчанию будет использовано значение «
pg_basebackup base backup
».-n
--no-clean
По умолчанию, когда программа
pg_basebackup
прерывается с ошибкой, она удаляет все каталоги, которые она могла создать, прежде чем обнаружила, что не может завершить задание (например, каталог данных и каталог журнала предзаписи). Данный ключ отключает эту очистку и тем самым полезен для отладки.Заметьте, что каталоги табличных пространств не очищаются в любом случае.
-P
--progress
Включает отчёт о прогрессе. Если этот режим включён, то во время создания копии будет передаваться примерный процент выполнения. Так как данные в базе могут меняться во время копирования, это значение будет лишь приближённым и может достигать не точно
100%
. В частности, когда в копию включается журнал WAL, конечный размер невозможно предсказать заранее, и в этом случае ожидаемый конечный размер будет увеличиваться, превысив ориентировочный полный размер без WAL.Если режим включён, то процесс копирования начнется с перечисления размеров всей базы, а затем продолжится отправкой непосредственно данных. Это может немного увеличить время операции, в частности, пройдёт больше времени до начала передачи данных.
-N
--no-sync
По умолчанию
pg_basebackup
ждёт, пока все файлы не будут надёжно записаны на диск. С данным параметромpg_basebackup
завершается немедленно, то есть выполняется быстрее, но в случае неожиданного сбоя операционной системы резервная копия может оказаться испорченной. Вообще этот параметр предназначен прежде всего для тестирования, для производственной среды он не подходит.-v
--verbose
Включает режим подробного вывода. Будет выводится некоторая дополнительная информация при начале и завершении, а также имена обрабатываемых файлов, если включён отчёт о прогрессе.
Далее описаны параметры управления подключением.
-d
строка_подключения
--dbname=
строка_подключения
Указывает параметры подключения к серверу в формате строки подключения; они будут переопределять любые одноимённые параметры, заданные в командной строке.
Параметр называется
--dbname
для согласованности с другими клиентскими приложениями, но так как pg_basebackup не подключается к какой-либо конкретной базе, это имя в строке подключения игнорируется.-h
сервер
--host=
сервер
Указывает имя компьютера, на котором работает сервер. Если значение начинается с косой черты, оно определяет каталог Unix-сокета. Значение по умолчанию берётся из переменной окружения
PGHOST
, если она установлена. В противном случае выполняется подключение к Unix-сокету.-p
порт
--port=
порт
Указывает TCP-порт или расширение файла локального Unix-сокета, через который сервер принимает подключения. Значение по умолчанию определяется переменной окружения
PGPORT
, если она установлена, либо числом, заданным при компиляции.-s
interval
--status-interval=
interval
Указывает интервал в секундах между отправкой пакетов статуса, отправляемых на сервер. Это позволяет упростить мониторинг прогресса. Чтобы выключить периодическое обновление статуса, необходимо установить значение в ноль. При этом обновление будет отправляться по запросу сервера для избежания отсоединения по истечению времени. Значение по умолчанию составляет 10 секунд.
-U
имя_пользователя
--username=
имя_пользователя
Имя пользователя, под которым производится подключение.
-w
--no-password
Не выдавать запрос на ввод пароля. Если сервер требует аутентификацию по паролю и пароль не доступен с помощью других средств, таких как файл
.pgpass
, попытка соединения не удастся. Этот параметр может быть полезен в пакетных заданиях и скриптах, где нет пользователя, который вводит пароль.-W
--password
Принудительно запрашивать пароль перед подключением к базе данных.
Это несущественный параметр, так как pg_basebackup запрашивает пароль автоматически, если сервер проверяет подлинность по паролю. Однако чтобы понять это, pg_basebackup лишний раз подключается к серверу. Поэтому иногда имеет смысл ввести
-W
, чтобы исключить эту ненужную попытку подключения.
Другие флаги:
-V
--version
Вывести версию pg_basebackup.
-?
--help
Вывести справку по команде pg_basebackup.
Переменные окружения
Как и большинство других утилит Postgres Pro, приложение также использует переменные окружения, поддерживаемые libpq (см. Раздел 31.14).
Замечания
Прежде чем начнётся копирование, на сервере с копируемой базой необходимо выполнить контрольную точку. И если копирование запускается без ключа --checkpoint=fast
, это может занять некоторое время, в течение которого pg_basebackup не будет проявлять никакой активности.
Резервная копия будет включать в себя все файлы каталога хранения данных и табличных пространств, а также конфигурационные файлы и прочие файлы, размещённые в каталоге данных, за исключением определённых временных файлов, принадлежащих Postgres Pro. Однако копируются лишь простые файлы и каталоги, кроме них, сохраняются только символические ссылки на табличные пространства. Символические ссылки, указывающие на определённые каталоги, известные Postgres Pro, копируются как пустые каталоги. Другие символические ссылки и файлы спецустройств игнорируются. За дополнительными подробностями обратитесь к Разделу 50.4.
Если не указан параметр --tablespace-mapping
, табличные пространства в простом формате будут копироваться в тот же путь, который они имеют на сервере. Поэтому при наличии табличных пространств создать базовую копию в простом формате на том же сервере не удастся, так как копия будет направлена в те же каталоги, где располагаются исходные табличные пространства.
Когда применяется режим формата tar, пользователь должен позаботиться о том, чтобы все архивы tar были распакованы до запуска сервера Postgres Pro. Если имеются дополнительные табличные пространства, архивы tar для них должны быть распакованы в правильные каталоги. В таком случае для этих табличных пространств сервером будут созданы символические ссылки, согласно содержимому файла tablespace_map
, включённого в архив base.tar
.
pg_basebackup совместим с серверами той же или более младших версий, но не ниже 9.1. Однако режим трансляции WAL (-X stream
) поддерживается с версиями сервера не ниже 9.3, а режим формата tar (--format=tar
) текущей версии совместим только с версиями сервера не ниже 9.5.
Примеры
Создание резервной копии сервера mydbserver
и сохранение её в локальном каталоге /usr/local/pgsql/data
:
$
pg_basebackup -h mydbserver -D /usr/local/pgsql/data
Создание резервной копии локального сервера в отдельных сжатых файлах tar для каждого табличного пространства и сохранение их в каталоге backup
с индикатором прогресса в процессе выполнения:
$
pg_basebackup -D backup -Ft -z -P
Создание резервной копии локальной базы данных с одним табличным пространством и сжатие её с помощью bzip2:
$
pg_basebackup -D - -Ft -X fetch | bzip2 > backup.tar.bz2
(Эта команда прервётся с ошибкой, если в базе данных будет несколько табличных пространств.)
Создание резервной копии локальной базы данных с перемещением табличного пространства /opt/ts
в ./backup/ts
:
$
pg_basebackup -D backup/data -T /opt/ts=$(pwd)/backup/ts
См. также
pg_dumppg_basebackup
pg_basebackup — take a base backup of a Postgres Pro cluster
Synopsis
pg_basebackup
[option
...]
Description
pg_basebackup is used to take base backups of a running Postgres Pro database cluster. These are taken without affecting other clients to the database, and can be used both for point-in-time recovery (see Section 24.3) and as the starting point for a log shipping or streaming replication standby servers (see Section 25.2).
pg_basebackup makes a binary copy of the database cluster files, while making sure the system is put in and out of backup mode automatically. Backups are always taken of the entire database cluster; it is not possible to back up individual databases or database objects. For individual database backups, a tool such as pg_dump must be used.
The backup is made over a regular Postgres Pro connection, and uses the replication protocol. The connection must be made with a superuser or a user having REPLICATION
permissions (see Section 20.2), and pg_hba.conf
must explicitly permit the replication connection. The server must also be configured with max_wal_senders set high enough to leave at least one session available for the backup and one for WAL streaming (if used).
There can be multiple pg_basebackup
s running at the same time, but it is better from a performance point of view to take only one backup, and copy the result.
pg_basebackup can make a base backup from not only the master but also the standby. To take a backup from the standby, set up the standby so that it can accept replication connections (that is, set max_wal_senders
and hot_standby, and configure host-based authentication). You will also need to enable full_page_writes on the master.
Note that there are some limitations in an online backup from the standby:
The backup history file is not created in the database cluster backed up.
pg_basebackup cannot force the standby to switch to a new WAL file at the end of backup. When you are using
-X none
, if write activity on the primary is low, pg_basebackup may need to wait a long time for the last WAL file required for the backup to be switched and archived. In this case, it may be useful to runpg_switch_wal
on the primary in order to trigger an immediate WAL file switch.If the standby is promoted to the master during online backup, the backup fails.
All WAL records required for the backup must contain sufficient full-page writes, which requires you to enable
full_page_writes
on the master and not to use a tool like pg_compresslog asarchive_command
to remove full-page writes from WAL files.
Options
The following command-line options control the location and format of the output.
-D
directory
--pgdata=
directory
Directory to write the output to. pg_basebackup will create the directory and any parent directories if necessary. The directory may already exist, but it is an error if the directory already exists and is not empty.
When the backup is in tar mode, and the directory is specified as
-
(dash), the tar file will be written tostdout
.This option is required.
-F
format
--format=
format
Selects the format for the output.
format
can be one of the following:p
plain
Write the output as plain files, with the same layout as the current data directory and tablespaces. When the cluster has no additional tablespaces, the whole database will be placed in the target directory. If the cluster contains additional tablespaces, the main data directory will be placed in the target directory, but all other tablespaces will be placed in the same absolute path as they have on the source server. (See
--tablespace-mapping
to change that.)This is the default format.
t
tar
Write the output as tar files in the target directory. The main data directory will be written to a file named
base.tar
, and all other tablespaces will be named after the tablespace OID.If the value
-
(dash) is specified as target directory, the tar contents will be written to standard output, suitable for piping to for example gzip. This is only possible if the cluster has no additional tablespaces and WAL streaming is not used.
-r
rate
--max-rate=
rate
The maximum transfer rate of data transferred from the server. Values are in kilobytes per second. Use a suffix of
M
to indicate megabytes per second. A suffix ofk
is also accepted, and has no effect. Valid values are between 32 kilobytes per second and 1024 megabytes per second.The purpose is to limit the impact of pg_basebackup on the running server.
This option always affects transfer of the data directory. Transfer of WAL files is only affected if the collection method is
fetch
.-R
--write-recovery-conf
Write a minimal
recovery.conf
in the output directory (or into the base archive file when using tar format) to ease setting up a standby server. Therecovery.conf
file will record the connection settings and, if specified, the replication slot that pg_basebackup is using, so that the streaming replication will use the same settings later on.-S
slotname
--slot=
slotname
This option can only be used together with
-X stream
. It causes the WAL streaming to use the specified replication slot. If the base backup is intended to be used as a streaming replication standby using replication slots, it should then use the same replication slot name inrecovery.conf
. That way, it is ensured that the server does not remove any necessary WAL data in the time between the end of the base backup and the start of streaming replication.If this option is not specified and the server supports temporary replication slots (version 10 and later), then a temporary replication slot is automatically used for WAL streaming.
--no-slot
This option prevents the creation of a temporary replication slot during the backup even if it's supported by the server.
Temporary replication slots are created by default if no slot name is given with the option
-S
when using log streaming.The main purpose of this option is to allow taking a base backup when the server is out of free replication slots. Using replication slots is almost always preferred, because it prevents needed WAL from being removed by the server during the backup.
-T
olddir
=newdir
--tablespace-mapping=
olddir
=newdir
Relocate the tablespace in directory
olddir
tonewdir
during the backup. To be effective,olddir
must exactly match the path specification of the tablespace as it is currently defined. (But it is not an error if there is no tablespace inolddir
contained in the backup.) Botholddir
andnewdir
must be absolute paths. If a path happens to contain a=
sign, escape it with a backslash. This option can be specified multiple times for multiple tablespaces. See examples below.If a tablespace is relocated in this way, the symbolic links inside the main data directory are updated to point to the new location. So the new data directory is ready to be used for a new server instance with all tablespaces in the updated locations.
Currently, this option only works with plain output format; it is ignored if tar format is selected.
--waldir=
waldir
Specifies the location for the write-ahead log directory.
waldir
must be an absolute path. The write-ahead log directory can only be specified when the backup is in plain mode.-X
method
--wal-method=
method
Includes the required write-ahead log files (WAL files) in the backup. This will include all write-ahead logs generated during the backup. Unless the method
none
is specified, it is possible to start a postmaster directly in the extracted directory without the need to consult the log archive, thus making this a completely standalone backup.The following methods for collecting the write-ahead logs are supported:
n
none
Don't include write-ahead log in the backup.
f
fetch
The write-ahead log files are collected at the end of the backup. Therefore, it is necessary for the wal_keep_segments parameter to be set high enough that the log is not removed before the end of the backup. If the log has been rotated when it's time to transfer it, the backup will fail and be unusable.
When tar format mode is used, the write-ahead log files will be written to the
base.tar
file.s
stream
Stream the write-ahead log while the backup is created. This will open a second connection to the server and start streaming the write-ahead log in parallel while running the backup. Therefore, it will use up two connections configured by the max_wal_senders parameter. As long as the client can keep up with write-ahead log received, using this mode requires no extra write-ahead logs to be saved on the master.
When tar format mode is used, the write-ahead log files will be written to a separate file named
pg_wal.tar
(if the server is a version earlier than 10, the file will be namedpg_xlog.tar
).This value is the default.
-z
--gzip
Enables gzip compression of tar file output, with the default compression level. Compression is only available when using the tar format, and the suffix
.gz
will automatically be added to all tar filenames.-Z
level
--compress=
level
Enables gzip compression of tar file output, and specifies the compression level (0 through 9, 0 being no compression and 9 being best compression). Compression is only available when using the tar format, and the suffix
.gz
will automatically be added to all tar filenames.
The following command-line options control the generation of the backup and the running of the program.
-c
fast|spread
--checkpoint=
fast|spread
Sets checkpoint mode to fast (immediate) or spread (default) (see Section 24.3.3).
-l
label
--label=
label
Sets the label for the backup. If none is specified, a default value of “
pg_basebackup base backup
” will be used.-n
--no-clean
By default, when
pg_basebackup
aborts with an error, it removes any directories it might have created before discovering that it cannot finish the job (for example, data directory and write-ahead log directory). This option inhibits tidying-up and is thus useful for debugging.Note that tablespace directories are not cleaned up either way.
-P
--progress
Enables progress reporting. Turning this on will deliver an approximate progress report during the backup. Since the database may change during the backup, this is only an approximation and may not end at exactly
100%
. In particular, when WAL log is included in the backup, the total amount of data cannot be estimated in advance, and in this case the estimated target size will increase once it passes the total estimate without WAL.When this is enabled, the backup will start by enumerating the size of the entire database, and then go back and send the actual contents. This may make the backup take slightly longer, and in particular it will take longer before the first data is sent.
-N
--no-sync
By default,
pg_basebackup
will wait for all files to be written safely to disk. This option causespg_basebackup
to return without waiting, which is faster, but means that a subsequent operating system crash can leave the base backup corrupt. Generally, this option is useful for testing but should not be used when creating a production installation.-v
--verbose
Enables verbose mode. Will output some extra steps during startup and shutdown, as well as show the exact file name that is currently being processed if progress reporting is also enabled.
The following command-line options control the database connection parameters.
-d
connstr
--dbname=
connstr
Specifies parameters used to connect to the server, as a connection string; these will override any conflicting command line options.
The option is called
--dbname
for consistency with other client applications, but because pg_basebackup doesn't connect to any particular database in the cluster, database name in the connection string will be ignored.-h
host
--host=
host
Specifies the host name of the machine on which the server is running. If the value begins with a slash, it is used as the directory for the Unix domain socket. The default is taken from the
PGHOST
environment variable, if set, else a Unix domain socket connection is attempted.-p
port
--port=
port
Specifies the TCP port or local Unix domain socket file extension on which the server is listening for connections. Defaults to the
PGPORT
environment variable, if set, or a compiled-in default.-s
interval
--status-interval=
interval
Specifies the number of seconds between status packets sent back to the server. This allows for easier monitoring of the progress from server. A value of zero disables the periodic status updates completely, although an update will still be sent when requested by the server, to avoid timeout disconnect. The default value is 10 seconds.
-U
username
--username=
username
User name to connect as.
-w
--no-password
Never issue a password prompt. If the server requires password authentication and a password is not available by other means such as a
.pgpass
file, the connection attempt will fail. This option can be useful in batch jobs and scripts where no user is present to enter a password.-W
--password
Force pg_basebackup to prompt for a password before connecting to a database.
This option is never essential, since pg_basebackup will automatically prompt for a password if the server demands password authentication. However, pg_basebackup will waste a connection attempt finding out that the server wants a password. In some cases it is worth typing
-W
to avoid the extra connection attempt.
Other options are also available:
-V
--version
Print the pg_basebackup version and exit.
-?
--help
Show help about pg_basebackup command line arguments, and exit.
Environment
This utility, like most other Postgres Pro utilities, uses the environment variables supported by libpq (see Section 31.14).
Notes
At the beginning of the backup, a checkpoint needs to be written on the server the backup is taken from. Especially if the option --checkpoint=fast
is not used, this can take some time during which pg_basebackup will be appear to be idle.
The backup will include all files in the data directory and tablespaces, including the configuration files and any additional files placed in the directory by third parties, except certain temporary files managed by Postgres Pro. But only regular files and directories are copied, except that symbolic links used for tablespaces are preserved. Symbolic links pointing to certain directories known to Postgres Pro are copied as empty directories. Other symbolic links and special device files are skipped. See Section 50.4 for the precise details.
Tablespaces will in plain format by default be backed up to the same path they have on the server, unless the option --tablespace-mapping
is used. Without this option, running a plain format base backup on the same host as the server will not work if tablespaces are in use, because the backup would have to be written to the same directory locations as the original tablespaces.
When tar format mode is used, it is the user's responsibility to unpack each tar file before starting the Postgres Pro server. If there are additional tablespaces, the tar files for them need to be unpacked in the correct locations. In this case the symbolic links for those tablespaces will be created by the server according to the contents of the tablespace_map
file that is included in the base.tar
file.
pg_basebackup works with servers of the same or an older major version, down to 9.1. However, WAL streaming mode (-X stream
) only works with server version 9.3 and later, and tar format mode (--format=tar
) of the current version only works with server version 9.5 or later.
Examples
To create a base backup of the server at mydbserver
and store it in the local directory /usr/local/pgsql/data
:
$
pg_basebackup -h mydbserver -D /usr/local/pgsql/data
To create a backup of the local server with one compressed tar file for each tablespace, and store it in the directory backup
, showing a progress report while running:
$
pg_basebackup -D backup -Ft -z -P
To create a backup of a single-tablespace local database and compress this with bzip2:
$
pg_basebackup -D - -Ft -X fetch | bzip2 > backup.tar.bz2
(This command will fail if there are multiple tablespaces in the database.)
To create a backup of a local database where the tablespace in /opt/ts
is relocated to ./backup/ts
:
$
pg_basebackup -D backup/data -T /opt/ts=$(pwd)/backup/ts