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