linux服务器自动备份数据

#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天前的备份文件(注意:{} \;中间有空格)

 

 

 

posted @ 2013-05-29 14:54  独行客  阅读(498)  评论(0编辑  收藏  举报