linux下mysql自动备份脚本代码

脚本放在 /home/user/mysql_backup.sh 
crontab 
# crontab -l 
# m h dom mon dow command 
28 16 * * * /home/user/mysql_backup.sh 
脚本如下 
 MsP迪尔课堂自学网---官网 (迪尔掌上课堂)

复制代码代码如下:
MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
#!/bin/sh MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# mysql_backup.sh: backup mysql databases and keep newest 5 days backup. MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# Last updated: 20 March 2006 MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# ---------------------------------------------------------------------- MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# This is a free shell script under GNU GPL version 2.0 or above MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# Copyright (C) 2006 Sam Tang MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# Feedback/comment/suggestions : http://www.real-blog.com/ MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# ---------------------------------------------------------------------- MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# your mysql login information MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# db_user is mysql username MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# db_passwd is mysql password MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# db_host is mysql host MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# ----------------------------- MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
db_user="root" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
db_passwd="password" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
db_host="localhost" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# the directory for story your backup file. MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
backup_dir="/home/mybackup" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# date format for backup file (dd-mm-yyyy) MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
time="$(date +"%d-%m-%Y")" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# mysql, mysqldump and some other bin's path MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
MYSQL="/usr/local/mysql/bin/mysql" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
MYSQLDUMP="/usr/local/mysql/bin/mysqldump" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
MKDIR="/bin/mkdir" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
RM="/bin/rm" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
MV="/bin/mv" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
GZIP="/bin/gzip" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# check the directory for store backup is writeable MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
test ! -w $backup_dir && echo "Error: $backup_dir is un-writeable." && exit 0 MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# the directory for story the newest backup MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
test ! -d "$backup_dir/backup.0/" && $MKDIR "$backup_dir/backup.0/" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# get all databases MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
all_db="$($MYSQL -u $db_user -h $db_host -p$db_passwd -Bse 'show databases')" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
for db in $all_db MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
do MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
$MYSQLDUMP -u $db_user -h $db_host -p$db_passwd $db | $GZIP -9 > "$backup_dir/backup.0/$time.$db.gz" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
done MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# delete the oldest backup MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
test -d "$backup_dir/backup.5/" && $RM -rf "$backup_dir/backup.5" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
# rotate backup directory MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
for int in 4 3 2 1 0 MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
do MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
if(test -d "$backup_dir"/backup."$int") MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
then MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
next_int=`expr $int + 1` MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
$MV "$backup_dir"/backup."$int" "$backup_dir"/backup."$next_int" MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
fi MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
done MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
exit 0; MsP迪尔课堂自学网---官网 (迪尔掌上课堂)
 


 MsP迪尔课堂自学网---官网 (迪尔掌上课堂)

扫一扫手机访问