使用mysqlhotcopy进行备份(要求数据表类型为MYISAM类型)
下面给出shell脚本,大家可以根据自己的实际需要对其进行修改,以完成自己需要的功能.
#!/bin/sh
#
# mysql data stored dir
TODAY=`date +%y%m%d`
STOREDIR=/backup/data/$TODAY
mkdir $STOREDIR
# MYSQL database be backuped by the tool mysqlhotcopy
mysqlhotcopy mysql $STOREDIR
mysqlhotcopy test $STOREDIR
mysqlhotcopy bbs $STOREDIR
## go to /mnt/data/ directory where the backup files been intored
cd /backup/data/
## delete overdue mysql database backup files
## overdue time is 15 days
FIFTEENDAYSAGO=`date +%y%m%d --date='15 days ago'`
rm -rf $FIFTEENDAYSAGO
rm -f $FIFTEENDAYSAGO.tar.gz
## compress backup file by the tool tar
tar --remove-files -zcf $TODAY.tar.gz $TODAY
rm -rf $TODAY
上面shell脚本的一些说明:
/backup/data/ 为所有数据库备份的存放目录.
STOREDIR=/backup/data/$TODAY 为今日(脚本执行的那天)数据库备份的存放目录,需要执行mkdir $STOREDIR 进行生成.
mysqlhotcopy mysql $STOREDIR
mysqlhotcopy test $STOREDIR
mysqlhotcopy bbs $STOREDIR
这三句就是对mysql,test,bbs三个数据库进行热备份.(使用mysqlhotcopy进行热备份不需要关闭数据库).如果你机器上不能直接
执行mysqlhotcopy命令,则可以替换为mysqlhotcopy所在位置的完整路径,如: 假设数据库服务器安装在/usr/local/mysql目录下,则
可使用 /usr/local/mysql/bin/mysqlhotcopy mysql $STOREDIR 把mysql数据库热备份到$STOREDIR目录下.
FIFTEENDAYSAGO=`date +%y%m%d --date='15 days ago'`
rm -f $FIFTEENDAYSAGO.tar.gz
只保留15天内的备份数据库. 对15天之前的备份进行清除.
tar --remove-files -zcf $TODAY.tar.gz $TODAY
对备份进行压缩,这样可以节省许多空间.
rm -rf $TODAY 删除压缩后遗留的目录
可以把这个脚本取为任何你想要的名字,如backup.shell,并赋予执行权限 chmod 700 backup.shell,
然后写入crontab中,如下:
30 1 * * * /root/backup.sh
让backup.sh脚本在凌晨1点半运行,对数据库进行备份.