Резервное копирование и восстановление

В разделе описаны способы создания и восстановления резервных копий системы.

Резервное копирование скриптом

Скрипт выполняет автоматическое формирование архивного файла, который включает резервные копии базы данных PostgreSQL, конфигурационные файлы сервисов, а также дополнительные данные: шаблоны и конфигурации nginx. Полученный архив может быть использован для восстановления системы при необходимости.

Для запуска необходимо выполнить команду:

curl -o "./backup.sh" "https://public-repo.svcp.io/utility/backup.sh" && \
    sudo chmod +x "./backup.sh" && \
    ./backup.sh

Архив резервной копии сохраняется в директории: /opt/backups/

Ручное резервное копирование

Подготовка

Создать директорию для резервных копий:

sudo mkdir -p /opt/backups

Создать временную директорию:

sudo mkdir -p /opt/backups/node0

Резервное копирование базы данных PostgreSQL

Проверить наличие файла конфигурации:

sudo ls -la /opt/sp-spider-broker/.env

Открыть файл и посмотреть значения переменных подключения к базе (DB_HOST, DB_PORT, DB_USER, DB_PASSWORD, DB_NAME). Эти параметры понадобятся для бэкапа:

sudo grep -E '^DB_' /opt/sp-spider-broker/.env

Создать директорию для бэкапа PostgreSQL:

sudo mkdir -p /opt/backups/node0/postgres

Выполнить резервное копирование PostgreSQL с использованием считанных параметров:

sudo PGPASSWORD="DB_PASSWORD" pg_dump \
    -h "DB_HOST" \
    -p "DB_PORT" \
    -U "DB_USER" \
    "DB_DATABASE" \
    > /opt/backups/node0/postgres/DB_DATABASE.sql

Резервное копирование конфигурационных файлов

Ядро системы (DosGate)

Создать директорию для резервной копии DosGate:

sudo mkdir -p /opt/backups/node0/dosgate

Скопировать конфигурационный файл:

sudo cp /etc/dosgate.conf /opt/backups/node0/dosgate/

Выполнить резервное копирование:

sudo dgadm --backup="/opt/backups/node0/dosgate/dgadm_backup" --no-lic

Сессионный модуль (DosGate-UH)

Создать директорию для резервной копии:

sudo mkdir -p /opt/backups/node0/dosgate-uh

Скопировать конфигурационный файл:

sudo cp /etc/dosgate-uh.conf /opt/backups/node0/dosgate-uh/

Веб-интерфейс (SP-Spider)

Внимание: Компонент может быть установлен на отдельной ноде. Операции выполняются на той ноде, где установлен веб-интерфейс.

Создать директорию для резервной копии:

sudo mkdir -p /opt/backups/node0/sp-spider

Скопировать конфигурационный файл:

sudo cp /opt/sp-spider/.env /opt/backups/node0/sp-spider/

Брокер сообщений (SP-Spider-Broker)

Создать директорию для резервной копии:

sudo mkdir -p /opt/backups/node0/sp-spider-broker

Скопировать конфигурационный файл:

sudo cp /opt/sp-spider-broker/.env /opt/backups/node0/sp-spider-broker/

Модуль анализа логов (RLOG)

Создать директорию для резервной копии:

sudo mkdir -p /opt/backups/node0/rlog

Скопировать конфигурационный файл:

sudo cp /opt/rlog/.env /opt/backups/node0/rlog/

Посмотреть значение RULES_FOLDER в файле .env модуля RLOG:

grep "RULES_FOLDER" /opt/rlog/.env

Создать директорию для правил в резервной копии:

sudo mkdir -p /opt/backups/node0/rlog/rules

Скопировать директорию с правилами RLOG:

sudo cp -r RULES_FOLDER /opt/backups/node0/rlog/

Модуль автоматической генерации правил (Autopilot)

Создать директорию для резервной копии:

sudo mkdir -p /opt/backups/node0/auto-rule

Скопировать конфигурационный файл:

sudo cp /opt/auto-rule/.env /opt/backups/node0/auto-rule/

Скопировать файлы лицензий:

sudo cp /opt/auto-rule/*.lic /opt/backups/node0/auto-rule/

Агент сбора метрик (Carbon-ClickHouse)

Создать директорию для резервной копии:

sudo mkdir -p /opt/backups/node0/carbon-clickhouse

Скопировать конфигурационный файл:

sudo cp /etc/carbon-clickhouse/carbon-clickhouse.conf /opt/backups/node0/carbon-clickhouse/

Хранилище метрик (Graphite-ClickHouse)

Создать директорию для резервной копии:

sudo mkdir -p /opt/backups/node0/graphite-clickhouse

Скопировать конфигурационный файл:

sudo cp /etc/graphite-clickhouse/graphite-clickhouse.conf /opt/backups/node0/graphite-clickhouse/

Nginx

Создать директорию для резервной копии:

sudo mkdir -p /opt/backups/node0/nginx

Скопировать конфигурационный файл:

sudo cp /etc/nginx/nginx.conf /opt/backups/node0/nginx/

Скопировать каталоги sites-enabled и sites-available:

sudo cp -r /etc/nginx/sites-* /opt/backups/node0/nginx/

Создание архива

Создать архив:

sudo tar -czf /opt/backups/node0.tar.gz -C /opt/backups node0

Удалить временную директорию:

sudo rm -rf /opt/backups/node0

Проверить результат:

ls -la /opt/backups/node0.tar.gz

Проверить содержимое архива (отобразить первые 20 файлов):

sudo tar -tzf /opt/backups/node0.tar.gz | head -20

В результате выполнения шагов сформирован архив /opt/backups/node0.tar.gz, содержащий резервные копии PostgreSQL и MongoDB, конфигурационные файлы сервисов и дополнительные данные (шаблоны, лицензии, конфигурации nginx)


Восстановление системы

Перейти в каталог /opt/backups/, найти архив с резервной копией и распаковать:

sudo tar -xzvf node0.tar.gz

Восстановление базы данных PostgreSQL

Перейти в каталог базы:

cd node0/postgres

Найти файл с расширением .sql.

При необходимости создать базу и пользователя:

sudo -u postgres psql
  • В консоли PostgreSQL выполнить:
CREATE DATABASE DB_DATABASE;
CREATE USER DB_USER WITH ENCRYPTED PASSWORD 'DB_PASSWORD';
GRANT ALL PRIVILEGES ON DATABASE DB_DATABASE TO DB_USER;
\q

Выполнить восстановление базы:

sudo PGPASSWORD="DB_PASSWORD" psql \
  -h "DB_HOST" \
  -p "DB_PORT" \
  -U "DB_USER" \
  -d "DB_DATABASE" \
  -f DB_DATABASE.sql

При необходимости обновить параметры подключения в конфигурационных файлах (.env) сервисов sp-spider, sp-spider-broker.

Перезапустить сервисы:

sudo systemctl restart sp-spider sp-spider-broker

Восстановление конфигурационных файлов

Ядро системы (DosGate)

Остановить Dosgate:

sudo systemctl stop dosgate

Очистить кэш:

sudo dgadm --batch=uh -y

Перейти в каталог с резервной копией:

cd node0/dosgate

Скопировать конфигурационный файл:

sudo cp ./dosgate.conf /etc/dosgate.conf

Выполнить восстановление конфигурации из резервной копии:

sudo dgadm --restore="/opt/backups/node0/dosgate/dgadm_backup" --no-lic

Запустить сервис:

sudo systemctl start dosgate

Сессионный модуль (DosGate-UH)

Перейти в каталог с резервной копией:

cd node0/dosgate-uh

Скопировать конфигурационный файл:

sudo cp ./dosgate-uh.conf /etc/dosgate-uh.conf

Перезапустить сервис:

sudo systemctl restart dosgate-uh

Веб-интерфейс (SP-Spider)

Внимание: Компонент может быть установлен на отдельной ноде. Операции выполняются на той ноде, где установлен веб-интерфейс.

Перейти в каталог с резервной копией:

cd node0/sp-spider

Скопировать конфигурационный файл:

sudo cp ./.env /opt/sp-spider/.env

Перезапустить сервис:

sudo systemctl restart sp-spider

Брокер сообщений (SP-Spider-Broker)

Перейти в каталог с резервной копией:

cd node0/sp-spider-broker

Скопировать конфигурационный файл:

sudo cp ./.env /opt/sp-spider-broker/.env

Перезапустить сервис:

sudo systemctl restart sp-spider-broker

Модуль анализа логов (RLOG)

Перейти в каталог с резервной копией:

cd node0/rlog

Скопировать конфигурационный файл:

sudo cp ./.env /opt/rlog/.env

Перезапустить сервис:

sudo systemctl restart rlog

Модуль автоматической генерации правил (Autopilot)

Перейти в каталог с резервной копией:

cd node0/auto-rule

Скопировать конфигурационный файл:

sudo cp ./.env /opt/auto-rule/.env

Скопировать файлы лицензий:

sudo cp ./*.lic /opt/auto-rule/*.lic

Перезапустить сервис:

sudo systemctl restart auto_rule

Агент сбора метрик (Carbon-ClickHouse)

Перейти в каталог с резервной копией:

cd node0/carbon-clickhouse

Скопировать конфигурационный файл:

sudo cp ./carbon-clickhouse.conf /etc/carbon-clickhouse/carbon-clickhouse.conf

Перезапустить сервис:

sudo systemctl restart carbon-clickhouse

Хранилище метрик (Graphite-ClickHouse)

Перейти в каталог с резервной копией:

cd node0/graphite-clickhouse

Скопировать конфигурационный файл:

sudo cp ./graphite-clickhouse.conf /etc/graphite-clickhouse/graphite-clickhouse.conf

Перезапустить сервис:

sudo systemctl restart graphite-clickhouse

Nginx

Перейти в каталог с резервной копией:

cd node0/nginx

Скопировать конфигурационный файл:

sudo cp ./nginx.conf /etc/nginx/nginx.conf

Скопировать каталоги sites-enabled и sites-available:

sudo cp -r ./sites-* /etc/nginx/

Перезапустить сервис:

sudo systemctl restart nginx