mysqlbackup.sh 1.14 KB
Newer Older
siick's avatar
siick committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
#!/bin/bash

# Configuration de la date
DATE=$(date +"%Y%m%d")

# Dossier où sauvegarder les backups (à créer d'abord!)
BACKUP_DIR="chemin/vers/dossier/de/sauvegarde"

# Identifiants MySQL
MYSQL_USER="user"
MYSQL_PASSWORD="identifiant"

# Commandes MySQL
MYSQL=/usr/bin/mysql
MYSQLDUMP=/usr/bin/mysqldump

# Bases de données MySQL à ignorer
SKIPDATABASES="Database|information_schema|performance_schema|mysql"

# Nombre de jours à garder les dossiers (seront effacés après X jours)
RETENTION=2

# ---- NE RIEN MODIFIER SOUS CETTE LIGNE ------------------------------------------
#
# Crée un nouveau répertoire dans le dossier de sauvegarde avec la date
mkdir -p $BACKUP_DIR/$DATE

# La liste des bases de données
databases=`$MYSQL -u$MYSQL_USER -p$MYSQL_PASSWORD -e "SHOW DATABASES;" | grep -Ev "($SKIPDATABASES)"`

# Sauvegarde les bases de données et gzip sur les fichiers .sql 
for db in $databases; do
echo $db
$MYSQLDUMP --force --opt --user=$MYSQL_USER -p$MYSQL_PASSWORD --skip-lock-tables --events --databases $db | gzip > "$BACKUP_DIR/$DATE/$db.sql.gz"
done

# Supprime les fichiers vieux de X jours
find $BACKUP_DIR/* -mtime +$RETENTION -delete