Come Eseguire un Backup Completo del Sito WordPress con uno Script Bash

Introduzione

Eseguire un backup completo del tuo sito WordPress è un’attività fondamentale per garantire la sicurezza e l’integrità dei tuoi dati. In questo articolo, ti presenteremo uno script Bash che automatizza il processo di backup, salvando sia i file del sito che il database MySQL. Automatizzare questa operazione ti permetterà di risparmiare tempo e assicurarti che i tuoi dati siano sempre protetti, anche in caso di errori o attacchi imprevisti.

Codice dello Script


#!/bin/bash

# Parametri di configurazione
BACKUP_DIR="/path/to/backup"
DB_NAME="your_database_name"
DB_USER="your_database_user"
DB_PASSWORD="your_database_password"
SITE_DIR="/path/to/wordpress"
DATE=$(date +"%Y%m%d%H%M")

# Backup del database
mysqldump -u $DB_USER -p$DB_PASSWORD $DB_NAME > $BACKUP_DIR/db_backup_$DATE.sql

# Backup dei file del sito
tar -czf $BACKUP_DIR/site_backup_$DATE.tar.gz -C $SITE_DIR .

# Rimuovi backup più vecchi di 30 giorni
find $BACKUP_DIR -type f -mtime +30 -delete

# Disclaimer: Codice creato da Evo Sistemi di Cirone Simone, info@evosistemi.com, www.evosistemi.com, +39 3662025885
        

Spiegazione Dettagliata

Analizziamo il codice riga per riga per comprendere meglio come funziona e come puoi personalizzarlo per le tue esigenze:

  • BACKUP_DIR: Questa variabile definisce la directory in cui verranno salvati i file di backup. Modificala con il percorso desiderato sul tuo server.
  • DB_NAME, DB_USER, DB_PASSWORD: Specifica il nome del database, il nome utente e la password utilizzati per l’accesso al database MySQL del tuo sito WordPress.
  • SITE_DIR: Indica il percorso della directory principale del tuo sito WordPress.
  • DATE: Crea un timestamp unico che verrà aggiunto ai nomi dei file di backup, rendendo ogni backup facilmente identificabile.
  • mysqldump: Questo comando effettua un backup completo del database MySQL, salvandolo come file SQL nella directory specificata.
  • tar -czf: Crea un archivio compresso (.tar.gz) di tutti i file del sito WordPress.
  • find … -delete: Rimuove automaticamente i backup più vecchi di 30 giorni per risparmiare spazio sul disco.

Guida Passo-Passo per l’Esecuzione dello Script

  1. Crea un nuovo file Bash sul tuo server, ad esempio backup_wordpress.sh.
  2. Copia e incolla il codice sopra riportato nel file.
  3. Modifica le variabili BACKUP_DIR, DB_NAME, DB_USER, DB_PASSWORD e SITE_DIR con i tuoi dati.
  4. Rendi eseguibile lo script con il comando chmod +x backup_wordpress.sh.
  5. Esegui lo script manualmente con ./backup_wordpress.sh o programma un cron job per eseguirlo automaticamente su base regolare (es. giornaliera o settimanale).

In caso di dubbi o difficoltà nell’implementazione dello script, non esitare a contattare Evo Sistemi di Cirone Simone. Siamo a disposizione per supportarti nella gestione e manutenzione del tuo sito WordPress.

FAQ

Posso modificare la frequenza con cui vengono eseguiti i backup?

Sì, puoi configurare un cron job per eseguire lo script a intervalli regolari, in base alle tue esigenze.

Dove vengono salvati i file di backup?

I file di backup vengono salvati nella directory specificata dalla variabile BACKUP_DIR. Assicurati che questa directory sia accessibile e sicura.

Come posso ripristinare un backup?

Puoi ripristinare un backup del database utilizzando il comando mysql e i file del sito decompressi dalla directory specificata. Contatta Evo Sistemi per assistenza dettagliata nel processo di ripristino.