База знаний Одина — Одинэсника › Форумы › ODIN — Форум по 1С Предприятию › Как создать инкрементный бэкап в PostgreSQL 17?
- В этой теме 1 ответ, 2 участника, последнее обновление 10 месяцев, 2 недели назад сделано  Odin — Одинэсник. Odin — Одинэсник.
- 
		АвторСообщения
- 
		
			- 
18 декабря 2024 в 20:15 #30990 OdineskiУчастник OdineskiУчастникКак в PostgreSQL 17 создать инкрементный бэкап? Дай подробную инструкцию и ссылки 
- 
18 декабря 2024 в 20:15 #30991 Odin — ОдинэсникУчастник Odin — ОдинэсникУчастникДля создания инкрементного бэкапа в PostgreSQL 17, вам нужно выполнить несколько шагов. Ниже представлена подробная инструкция: ### Шаг 1: Включение WAL Summary в PostgreSQL 1. **Войдите в psql под пользователем postgres:** 1С (Код)12bashsudo -u postgres psql2. **Включите summarize_wal:** 1С (Код)12sqlALTER SYSTEM SET summarize_wal = on;3. **Перезагрузите конфигурацию PostgreSQL:** 1С (Код)12sqlSELECT pg_reload_conf();### Шаг 2: Создание каталога для бэкапов 1. **Создайте директорию для полного бэкапа и инкрементальных бэкапов:** 1С (Код)123bashsudo mkdir -p /backups/fullbackupsudo mkdir -p /backups/{incr_Monday,incr_Tuesday,incr_Wednesday,incr_Thursday,incr_Friday}2. **Установите правильные права:** 1С (Код)12bashsudo chown -R postgres:postgres /backups && sudo chmod -R 755 /backups### Шаг 3: Создание полного бэкапа базы данных 1. **Запустите полное резервное копирование:** 1С (Код)12bashsudo -u postgres pg_basebackup -D /backups/fullbackup### Шаг 4: Создание инкрементальных бэкапов 1. **Создайте инкрементальные бэкапы для каждого дня недели:** 1С (Код)123456bashsudo -u postgres pg_basebackup --incremental=/backups/fullbackup/backup_manifest -D /backups/incr_Monday/sudo -u postgres pg_basebackup --incremental=/backups/incr_Monday/backup_manifest -D /backups/incr_Tuesday/sudo -u postgres pg_basebackup --incremental=/backups/incr_Tuesday/backup_manifest -D /backups/incr_Wednesday/sudo -u postgres pg_basebackup --incremental=/backups/incr_Wednesday/backup_manifest -D /backups/incr_Thursday/sudo -u postgres pg_basebackup --incremental=/backups/incr_Thursday/backup_manifest -D /backups/incr_Friday/### Шаг 5: Объединение бэкапов 1. **Создайте каталог для объединённого бэкапа:** 1С (Код)1234bashsudo mkdir -p /combinebackupsudo chown -R postgres:postgres /combinebackupsudo chmod -R 755 /combinebackup2. **Объедините полный и инкрементальные бэкапы:** 1С (Код)12bashsudo -u postgres pg_combinebackup /backups/fullbackup/ /backups/incr_Monday/ /backups/incr_Tuesday/ /backups/incr_Wednesday/ -o /combinebackup### Шаг 6: Проверка и восстановление из бэкапа 1. **Остановите PostgreSQL перед восстановлением:** 1С (Код)12bashsudo systemctl stop postgres2. **Копируйте файлы из объединённого бэкапа в директорию PostgreSQL:** 1С (Код)12bashsudo cp -r /combinebackup/* /var/lib/postgresql/data/3. **Запустите PostgreSQL:** 1С (Код)12bashsudo systemctl start postgres### Полезные ссылки — [Документация PostgreSQL по pg_basebackup](https://www.postgresql.org/docs/current/pgbasebackup.html) 
 — [Информация о WAL и инкрементных бэкапах](https://www.postgresql.org/docs/current/continuous-archiving.html)Эта инструкция поможет вам создать инкрементный бэкап в PostgreSQL 17. Рекомендую ознакомиться с документацией для более глубокого понимания процесса. 
 
- 
- 
		АвторСообщения
- Для ответа в этой теме необходимо авторизоваться.
