Настройка автоматических резервных копий

Материал из ARK-HOSTER.RU | Документация хостинга
Перейти к: навигация, поиск

Содержание

Настройка автоматических резервных копий

1. Подготовка системы

  • Войдите в систему под учетной записью с правами root или пользователя с правами sudo.
  • Убедитесь, что у вас есть достаточно места для хранения резервных копий.

2. Создание директории для резервных копий

Создание структуры директорий

1. Создайте основную директорию для бэкапов: sudo mkdir -p /backup/{daily,weekly,monthly}

2. Создайте директории для разных типов бэкапов: sudo mkdir -p /backup/{files,databases,configs,logs}

3. Установите правильные права доступа: sudo chown -R root:root /backup sudo chmod -R 755 /backup

3. Настройка резервного копирования файлов

Создание скрипта для файлов

1. Создайте скрипт резервного копирования: sudo nano /usr/local/bin/backup-files.sh

2. Добавьте содержимое: BACKUP_DIR="/backup/files" SOURCE_DIRS="/var/www /home /etc" DATE=$(date +%Y%m%d_%H%M%S) BACKUP_FILE="files_backup_$DATE.tar.gz" tar -czf $BACKUP_DIR/$BACKUP_FILE $SOURCE_DIRS if [ -f $BACKUP_DIR/$BACKUP_FILE ]; then echo "Backup created: $BACKUP_FILE" echo "Size: $(du -h $BACKUP_DIR/$BACKUP_FILE | cut -f1)" else echo "Error: Backup failed" exit 1 fi find $BACKUP_DIR -name "files_backup_*.tar.gz" -mtime +7 -delete echo "Backup completed successfully"

3. Сделайте скрипт исполняемым: sudo chmod +x /usr/local/bin/backup-files.sh

Резервное копирование с исключениями

1. Создайте файл исключений: sudo nano /backup/exclude.txt

2. Добавьте исключения: *.tmp *.log *.cache /tmp/* /var/tmp/* /var/cache/* /var/log/*

3. Обновите скрипт для использования исключений: tar -czf $BACKUP_DIR/$BACKUP_FILE --exclude-from=/backup/exclude.txt $SOURCE_DIRS

4. Настройка резервного копирования баз данных

Резервное копирование MySQL/MariaDB

1. Создайте скрипт для MySQL: sudo nano /usr/local/bin/backup-mysql.sh

2. Добавьте содержимое: BACKUP_DIR="/backup/databases" MYSQL_USER="backup_user" MYSQL_PASS="backup_password" DATE=$(date +%Y%m%d_%H%M%S) mysqldump -u $MYSQL_USER -p$MYSQL_PASS --all-databases > $BACKUP_DIR/mysql_full_backup_$DATE.sql for db in $(mysql -u $MYSQL_USER -p$MYSQL_PASS -e "SHOW DATABASES;" | grep -v "Database\|information_schema\|performance_schema\|mysql\|sys"); do mysqldump -u $MYSQL_USER -p$MYSQL_PASS $db > $BACKUP_DIR/${db}_backup_$DATE.sql done gzip $BACKUP_DIR/*_backup_$DATE.sql find $BACKUP_DIR -name "*_backup_*.sql.gz" -mtime +7 -delete echo "MySQL backup completed successfully"

3. Сделайте скрипт исполняемым: sudo chmod +x /usr/local/bin/backup-mysql.sh

Резервное копирование PostgreSQL

1. Создайте скрипт для PostgreSQL: sudo nano /usr/local/bin/backup-postgresql.sh

2. Добавьте содержимое: BACKUP_DIR="/backup/databases" PG_USER="postgres" DATE=$(date +%Y%m%d_%H%M%S) pg_dumpall -U $PG_USER > $BACKUP_DIR/postgresql_full_backup_$DATE.sql for db in $(psql -U $PG_USER -l -t | cut -d'|' -f1 | grep -v template | grep -v postgres); do pg_dump -U $PG_USER $db > $BACKUP_DIR/${db}_backup_$DATE.sql done gzip $BACKUP_DIR/*_backup_$DATE.sql find $BACKUP_DIR -name "*_backup_*.sql.gz" -mtime +7 -delete echo "PostgreSQL backup completed successfully"

5. Настройка автоматического резервного копирования

Настройка cron задач

1. Откройте crontab: sudo crontab -e

2. Добавьте задачи резервного копирования: 0 2 * * * /usr/local/bin/backup-files.sh 0 3 * * * /usr/local/bin/backup-mysql.sh 0 1 * * 0 /usr/local/bin/backup-full.sh 0 0 1 * * /usr/local/bin/backup-monthly.sh

Создание комплексного скрипта

1. Создайте полный скрипт резервного копирования: sudo nano /usr/local/bin/backup-full.sh

2. Добавьте содержимое: BACKUP_DIR="/backup" DATE=$(date +%Y%m%d_%H%M%S) LOG_FILE="/var/log/backup.log" log() { echo "$(date '+%Y-%m-%d %H:%M:%S') - $1" >> $LOG_FILE } log "Starting full backup" log "Backing up files..." /usr/local/bin/backup-files.sh log "Backing up databases..." /usr/local/bin/backup-mysql.sh log "Backing up configurations..." tar -czf $BACKUP_DIR/configs_backup_$DATE.tar.gz /etc log "Creating backup index..." ls -la $BACKUP_DIR > $BACKUP_DIR/backup_index.txt log "Full backup completed successfully"

3. Сделайте скрипт исполняемым: sudo chmod +x /usr/local/bin/backup-full.sh

6. Настройка удаленного резервного копирования

Использование rsync

1. Создайте скрипт для удаленного копирования: sudo nano /usr/local/bin/backup-remote.sh

2. Добавьте содержимое: REMOTE_HOST="backup-server.example.com" REMOTE_USER="backup" REMOTE_DIR="/backup/$(hostname)" LOCAL_DIR="/backup" DATE=$(date +%Y%m%d_%H%M%S) rsync -avz --delete $LOCAL_DIR/ $REMOTE_USER@$REMOTE_HOST:$REMOTE_DIR/ if [ $? -eq 0 ]; then echo "Remote backup completed successfully" else echo "Remote backup failed" exit 1 fi

Использование SCP

1. Создайте скрипт для копирования через SCP: sudo nano /usr/local/bin/backup-scp.sh

2. Добавьте содержимое: REMOTE_HOST="backup-server.example.com" REMOTE_USER="backup" REMOTE_DIR="/backup/$(hostname)" LOCAL_DIR="/backup" DATE=$(date +%Y%m%d_%H%M%S) scp -r $LOCAL_DIR/* $REMOTE_USER@$REMOTE_HOST:$REMOTE_DIR/ if [ $? -eq 0 ]; then echo "SCP backup completed successfully" else echo "SCP backup failed" exit 1 fi

7. Настройка мониторинга резервных копий

Создание скрипта мониторинга

1. Создайте скрипт мониторинга: sudo nano /usr/local/bin/backup-monitor.sh

2. Добавьте содержимое: BACKUP_DIR="/backup" LOG_FILE="/var/log/backup.log" ALERT_EMAIL="admin@example.com" LAST_BACKUP=$(find $BACKUP_DIR -name "*.tar.gz" -mtime -1 | wc -l) if [ $LAST_BACKUP -eq 0 ]; then echo "ALERT: No backup found in the last 24 hours" | mail -s "Backup Alert" $ALERT_EMAIL fi BACKUP_SIZE=$(du -sh $BACKUP_DIR | cut -f1) echo "Backup directory size: $BACKUP_SIZE" for backup in $(find $BACKUP_DIR -name "*.tar.gz" -mtime -1); do if ! tar -tzf $backup > /dev/null 2>&1; then echo "ALERT: Corrupted backup: $backup" | mail -s "Backup Alert" $ALERT_EMAIL fi done

3. Сделайте скрипт исполняемым: sudo chmod +x /usr/local/bin/backup-monitor.sh

Настройка алертов

1. Добавьте задачу мониторинга в crontab: 0 * * * * /usr/local/bin/backup-monitor.sh

8. Восстановление из резервных копий

Восстановление файлов

1. Создайте скрипт восстановления: sudo nano /usr/local/bin/restore-files.sh

2. Добавьте содержимое: BACKUP_DIR="/backup/files" RESTORE_DIR="/restore" echo "Available backups:" ls -la $BACKUP_DIR/*.tar.gz read -p "Enter backup filename: " BACKUP_FILE if [ ! -f $BACKUP_DIR/$BACKUP_FILE ]; then echo "Error: Backup file not found" exit 1 fi mkdir -p $RESTORE_DIR tar -xzf $BACKUP_DIR/$BACKUP_FILE -C $RESTORE_DIR echo "Files restored to $RESTORE_DIR"

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

1. Создайте скрипт восстановления MySQL: sudo nano /usr/local/bin/restore-mysql.sh

2. Добавьте содержимое: BACKUP_DIR="/backup/databases" MYSQL_USER="root" MYSQL_PASS="password" echo "Available MySQL backups:" ls -la $BACKUP_DIR/*.sql.gz read -p "Enter backup filename: " BACKUP_FILE if [ ! -f $BACKUP_DIR/$BACKUP_FILE ]; then echo "Error: Backup file not found" exit 1 fi gunzip -c $BACKUP_DIR/$BACKUP_FILE | mysql -u $MYSQL_USER -p$MYSQL_PASS echo "MySQL database restored successfully"

9. Оптимизация резервного копирования

Сжатие и дедупликация

1. Создайте оптимизированный скрипт: sudo nano /usr/local/bin/backup-optimized.sh

2. Добавьте содержимое: BACKUP_DIR="/backup" SOURCE_DIR="/var/www" DATE=$(date +%Y%m%d_%H%M%S) tar --create --gzip --file $BACKUP_DIR/optimized_backup_$DATE.tar.gz \ --exclude='*.tmp' \ --exclude='*.log' \ --exclude='*.cache' \ $SOURCE_DIR md5sum $BACKUP_DIR/optimized_backup_$DATE.tar.gz > $BACKUP_DIR/optimized_backup_$DATE.md5 echo "Optimized backup created: optimized_backup_$DATE.tar.gz"

Инкрементальное резервное копирование

1. Создайте скрипт инкрементального копирования: sudo nano /usr/local/bin/backup-incremental.sh

2. Добавьте содержимое: BACKUP_DIR="/backup" SOURCE_DIR="/var/www" DATE=$(date +%Y%m%d_%H%M%S) tar --create --gzip --file $BACKUP_DIR/incremental_backup_$DATE.tar.gz \ --newer-mtime="1 day ago" \ $SOURCE_DIR echo "Incremental backup created: incremental_backup_$DATE.tar.gz"

10. Устранение неполадок

Частые проблемы

1. Недостаточно места для бэкапа:

  • Проверьте свободное место: df -h
  • Очистите старые бэкапы: find /backup -name "*.tar.gz" -mtime +30 -delete

2. Ошибка прав доступа:

  • Проверьте права: ls -la /backup
  • Исправьте права: sudo chown -R root:root /backup

3. Бэкап не создается:

  • Проверьте логи: tail -f /var/log/backup.log
  • Проверьте cron: sudo systemctl status cron

Диагностика

1. Проверьте статус cron: sudo systemctl status cron

2. Проверьте логи cron: sudo tail -f /var/log/cron.log

3. Проверьте права на скрипты: ls -la /usr/local/bin/backup-*.sh

Заключение

Автоматическое резервное копирование настроено! Теперь ваши данные защищены регулярными бэкапами.

Для размещения ваших проектов с настроенным резервным копированием на надежном хостинге рекомендуем воспользоваться услугами [ARK-HOSTER.RU](https://ark-hoster.ru):

Наши специалисты помогут с настройкой резервного копирования и обеспечением безопасности ваших данных!