linux下mysql自动备份脚本代码

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

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


 r9i 迪尔课堂-官网-免费自学网站-迪尔掌上课堂

扫一扫手机访问