#vim /etc/crontab
在crontab里增加:
15 01 * * * root /home/mysql_bak.sh #表示每天1点15分执行备份
然后重启
#/etc/rc.d/init.d/crond restart
mysql_bak.sh内容如下:
#!/bin/sh
DUMP=/usr/bin/mysqldump #mysqldump备份程序执行路径
OUT_DIR=/home/mysql_data #备份文件存放路径
#LINUX_USER=root #系统用户名
DB_NAME=database_name #要备份的数据库名字
DB_USER=username #数据库用户名
DB_PASS=password #数据库密码
DAYS=7 #DAYS=7代表删除7天前的备份,即只保留最近7天的备份
cd $OUT_DIR #进入备份存放目录
DATE=`date +%Y_%m_%d` #获取当前系统时间
OUT_SQL="$DATE.sql" #备份数据库的文件名
TAR_SQL="database_name_db_bak_$DATE.tar.gz" #最终保存的数据库备份文件名
$DUMP -u$DB_USER -p$DB_PASS $DB_NAME --default-character-set=utf8 --skip-lock-tables > $OUT_SQL #备份
tar -zcvf $TAR_SQL $OUT_SQL #压缩为.tar.gz格式
rm -rf $OUT_SQL #删除.sql格式的备份文件
#chown $LINUX_USER:$LINUX_USER $OUT_DIR/$TAR_SQL #更改备份数据库文件的所有者
find $OUT_DIR -name "database_name_db_bak*" -type f -mtime +$DAYS -exec rm {} \;
#删除7天前的备份文件(注意:{} \;中间有空格)