Бекапы в Vertica
Vertica поддерживает создание и восстановление из бекапов без остановки базы данных.
Создание бекапа
Для начала необходимо создать конфигурационный файл бекапа:
[Misc] snapshotName = backup_snapshot restorePointLimit = 1 objects = test objectRestoreMode = createOrReplace [Database] dbName = data dbUser = dbadmin [Transmission] [Mapping] v_data_node0001 = 10.10.0.2:/var/storage/test
# сохраним этот файл в backup.ini
Тут мы описали правила для создания бекапа таблицы test
из базы данных data
. Для того, чтобы процесс заработал, необходимо иметь сервер для загрузки бекапа (в примере — сервер 10.10.0.2
) по протоколу ssh. Для этого достаточно настроить SSH доступ по ключу для пользователя dbadmin
на сервер 10.10.0.2
.
Такой же файл настроек можно сгенерить автоматически с помощью помощника:
/opt/vertica/bin/vbr --setupconfig
После этого можно запускать скрипт создания бекапа:
/opt/vertica/bin/vbr.py --task backup --config-file backup.ini
# Запускаем процесс создания бекапа
Вывод будет похожим на такой:
Preparing... Copying... [==================================================] 100% All child processes terminated successfully. Committing changes on all backup sites... backup done!
# Успешно завершенный бекап
Восстановление из бекапа
Как только бекап готов, мы можем в любой момент времени восстановиться из него:
/opt/vertica/bin/vbr --task restore --config-file backup.ini
# для восстановления указываем тот же файл конфигурации, что и при создании бекапа
В результате увидим что-то похожее:
Copying... 1871652633 out of 1871652633, 100% All child processes terminated successfully. restore done!
# Данные восстановлены из бекапа
Экспорт в CSV
Альтернативой встроенным бекапам может стать экспорт в CSV:
/opt/vertica/bin/vsql -U dbadmin -F ',' -P footer=off -A -c 'SELECT * from test' | gzip -f > /tmp/test.csv.gz
# Экспорт данных в CSV
Не забудьте сохранить структуру таблицы на случай, если сервер будет потерян безвозвратно. И учтите, что такой процесс будет очень медленным для крупных таблиц.
Для импорта данных обратно в таблицу стоит воспользоваться операцией COPY:
COPY test FROM '/tmp/test.csv.gz' GZIP DELIMITER ',' TRAILING NULLCOLS
# Импорт данных из бекапа в таблицу
Сообщить об опечатке
Текст, который будет отправлен нашим редакторам: