Налаштування резервного копіювання бази даних сайту

Наша компанія займається розробкою, підтримкою та обслуговуванням сайтів будь-якої складності. Від простих односторінкових сайтів до масштабних кластерних систем, побудованих на мікро сервісах. Досвід розробників підтверджено сертифікатами від вендорів.

Розробка та обслуговування будь-яких видів сайтів:

Інформаційні сайти або веб-програми
Сайти візитки, landing page, корпоративні сайти, онлайн каталоги, квіз, промо-сайти, блоги, ресурси новин, інформаційні портали, форуми, агрегатори
Сайти або веб-програми електронної комерції
Інтернет-магазини, B2B-портали, маркетплейси, онлайн-обмінники, кешбек-сайти, біржі, дропшиппінг-платформи, парсери товарів
Веб-програми для управління бізнес-процесами
CRM-системи, ERP-системи, корпоративні портали, системи управління виробництвом, парсери інформації
Сайти або веб-програми електронних послуг
Дошки оголошень, онлайн-школи, онлайн-кінотеатри, конструктори сайтів, портали надання електронних послуг, відеохостинги, тематичні портали

Це лише деякі з технічних типів сайтів, з якими ми працюємо, і кожен із них може мати свої специфічні особливості та функціональність, а також бути адаптованим під конкретні потреби та цілі клієнта.

Пропоновані послуги
Показано 1 з 1 послугУсі 2065 послуг
Налаштування резервного копіювання бази даних сайту
Середня
від 1 робочого дня до 3 робочих днів
Часті питання

Наші компетенції:

Етапи розробки

Останні роботи

  • image_website-b2b-advance_0.png
    Розробка сайту компанії B2B ADVANCE
    1262
  • image_web-applications_feedme_466_0.webp
    Розробка веб-додатків для компанії FEEDME
    1171
  • image_websites_belfingroup_462_0.webp
    Розробка веб-сайту для компанії БЕЛФІНГРУП
    874
  • image_ecommerce_furnoro_435_0.webp
    Розробка інтернет магазину для компанії FURNORO
    1094
  • image_crm_enviok_479_0.webp
    Розробка веб-додатків для компанії Enviok
    831
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Розробка веб-сайту для компанії ФІКСПЕР
    851

Налаштування резервного копіювання бази даних сайту

Резервне копіювання - страховка від втрати даних при збої обладнання, випадкового видалення, атаки ransomware. Стратегія 3-2-1: три копії, два різних носія, одна поза сайтом.

PostgreSQL: автоматичний скрипт резервної копії

#!/bin/bash
DB_NAME="myapp"
BACKUP_DIR="/var/backups/postgresql"
S3_BUCKET="s3://myapp-backups/postgresql"
TIMESTAMP=$(date +%Y-%m-%d_%H-%M-%S)
BACKUP_FILE="${BACKUP_DIR}/${DB_NAME}_${TIMESTAMP}.sql.gz"

pg_dump -U "$DB_NAME" "$DB_NAME" | gzip -9 > "$BACKUP_FILE"

aws s3 cp "$BACKUP_FILE" "${S3_BUCKET}/${DB_NAME}_${TIMESTAMP}.sql.gz" \
  --storage-class STANDARD_IA

find "$BACKUP_DIR" -name "*.sql.gz" -mtime +7 -delete

MySQL/MariaDB резервна копія

mysqldump --single-transaction --routines --triggers \
  myapp | gzip -9 > "/var/backups/mysql/myapp_$(date +%Y-%m-%d_%H-%M-%S).sql.gz"

Laravel Spatie Backup

Пакет spatie/laravel-backup автоматизує резервну копію БД та файлів:

// config/backup.php
return [
    'backup' => [
        'name' => 'myapp',
        'source' => [
            'databases' => ['mysql'],
            'files' => [
                'include' => [storage_path('app')],
            ],
        ],
        'destination' => [
            'disks' => ['s3'],
        ],
    ],
    'cleanup' => [
        'keep_all_backups_for_days' => 7,
        'keep_daily_backups_for_days' => 30,
        'keep_weekly_backups_for_weeks' => 8,
        'keep_monthly_backups_for_months' => 4,
    ],
];

php artisan backup:run
php artisan backup:clean

Перевірка резервної копії

Тест того, що резервну копію можна відновити:

LATEST=$(ls -t /var/backups/postgresql/*.sql.gz | head -1)

gunzip -c "$LATEST" | psql -U postgres -d myapp_test

USERS=$(psql -U postgres -d myapp_test -t -c "SELECT COUNT(*) FROM users;")
if [ "$USERS" -gt 0 ]; then
    echo "Перевірка резервної копії OK"
    curl -fsS https://hc-ping.com/your-uuid > /dev/null
fi

psql -U postgres -c "DROP DATABASE myapp_test;"

Тривалість реалізації

Автоматична резервна копія PostgreSQL/MySQL в S3 з ротацією: 1–2 дні. З перевіркою відновлення та Slack-сповіщеннями: 2–3 дні.