Налаштування резервного копіювання бази даних сайту
Резервне копіювання - страховка від втрати даних при збої обладнання, випадкового видалення, атаки 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 дні.







