Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2147821
  • 博文数量: 227
  • 博客积分: 10521
  • 博客等级: 上将
  • 技术积分: 3452
  • 用 户 组: 普通用户
  • 注册时间: 2006-10-20 14:59
个人简介

低调做人,高调做事!

文章分类

全部博文(227)

文章存档

2013年(4)

2012年(8)

2011年(16)

2010年(24)

2009年(92)

2008年(83)

分类: LINUX

2008-03-24 23:06:44

将数据库直接复制一份,自动加锁,只适用于MYISAM表,脚本如下:
 
#! /bin/bash
# use like this : hotcopydb db1 db2 db3 ...
 
dbsum=$#
backdir=/opt/hotbackup/myisam
if [ "${dbsum}" -eq 0 ];then
        echo "Error:no database chosed"
        exit 1
fi
if [ -d ${backdir} ];then
        echo "${backdir} exist!"
else
        mkdir -p ${backdir}
fi
 
LogFile=/var/log/hotcopy_backup.log
touch $LogFile
datetime=`date +"%Y%m%d%H%M%S"`
hotcopypath=${backdir}${datetime}
mkdir -p ${hotcopypath}
echo "------------------------------------------------------------------" >> $LogFile
cd ${backdir}
while [ "`ls  ${backdir} | wc -l`" -gt 2 ]
do
        rm -rf `ls | head -1`
done
echo "hotcopy start at [`date +"%Y-%m-%d %H:%M:%S"`]" >> $LogFile
for i in $*;do
        echo "backing up for database $i starting ..."
        /usr/local/mysql/bin/mysqlhotcopy -uroot -p123456 --flushlog $i ${hotcopypath}
        echo "backing up for database $i completed"
done
echo "hotcopy   end at [`date +"%Y-%m-%d %H:%M:%S"`]" >> $LogFile
echo "tar and gzip the backed file now ..." >> $LogFile
cd ${backdir}
tar zcvf  ${datetime}.tar.gz ${datetime}
rm -rf  ${datetime}
echo "all success ! you  can find the backed file in ${backdir} suffixed by .tar.gz" >> $LogFile
exit 0
阅读(1758) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~