返回自动打包mys......登陆

自动打包mysql下binlog日志

高洛峰2016-11-15 11:01:04423

一、需求

线上一台机器做了rsync,从5台mysql机器拉取binlog日志到本地,之前是手动打包,现在写了个脚本,放到crontab定期执行打包,并删除打包后的的文件。


二、脚本如下

#!/bin/sh
# usage: 
# nohup sh /tmp/backup_binlog_tar.sh > nohup.out  2>/dev/null  &
 
 
dir_backup_tar="/data0/backup_log-bin_tar"_`date +%Y-%m-%d--%H-%M-%S`
echo $dir_backup_tar
mkdir -p $dir_backup_tar
 
#!/bin/sh
# usage: 
# nohup sh /tmp/backup_binlog_tar.sh > nohup.out  2>/dev/null  &
 
 
dir_backup_tar="/data0/backup_log-bin_tar"_`date +%Y-%m-%d--%H-%M-%S`
echo $dir_backup_tar
mkdir -p $dir_backup_tar
 
 
dir_binlog_140="/data0/backup_log-bin/140/log-bin"
dir_binlog_141="/data0/backup_log-bin/141/log-bin"
dir_binlog_145="/data0/backup_log-bin/145/log-bin"
dir_binlog_146="/data0/backup_log-bin/146/log-bin"
dir_binlog_182="/data0/backup_log-bin/182/log-bin"
 
 
instance_seq=140
dir_binlog=$dir_binlog_140
if [ ! -d $dir_binlog ]; then
        echo "$dir_binlog is not exit and skip!" 
fi
for instance in `ls $dir_binlog`
do
        cd $dir_binlog
        tar -zcf $dir_backup_tar/"$instance_seq""_""$instance"".tar.gz" $instance
        if [ $? -eq 0 ];then
                echo "delete $dir_binlog/$instance/* ..."
                rm -rf $dir_binlog/$instance/*
        else
                echo "tar $dir_binlog/$instance failed!!!"
        fi
done
 
 
instance_seq=141
dir_binlog=$dir_binlog_141
if [ ! -d $dir_binlog ]; then
        echo "$dir_binlog is not exit and skip!" 
fi
for instance in `ls $dir_binlog`
do
        cd $dir_binlog
        tar -zcf $dir_backup_tar/"$instance_seq""_""$instance"".tar.gz" $instance
        if [ $? -eq 0 ];then
                echo "delete $dir_binlog/$instance/* ..."
                rm -rf $dir_binlog/$instance/*
        else
                echo "tar $dir_binlog/$instance failed!!!"
        fi
done
 
 
instance_seq=145
dir_binlog=$dir_binlog_145
if [ ! -d $dir_binlog ]; then
        echo "$dir_binlog is not exit and skip!" 
fi
for instance in `ls $dir_binlog`
do
        cd $dir_binlog
        tar -zcf $dir_backup_tar/"$instance_seq""_""$instance"".tar.gz" $instance
        if [ $? -eq 0 ];then
                echo "delete $dir_binlog/$instance/* ..."
                rm -rf $dir_binlog/$instance/*
        else
                echo "tar $dir_binlog/$instance failed!!!"
        fi
done
 
 
instance_seq=146
dir_binlog=$dir_binlog_146
if [ ! -d $dir_binlog ]; then
        echo "$dir_binlog is not exit and skip!" 
fi
for instance in `ls $dir_binlog`
do
        cd $dir_binlog
        tar -zcf $dir_backup_tar/"$instance_seq""_""$instance"".tar.gz" $instance
        if [ $? -eq 0 ];then
                echo "delete $dir_binlog/$instance/* ..."
                rm -rf $dir_binlog/$instance/*
        else
                echo "tar $dir_binlog/$instance failed!!!"
        fi
done
 
 
instance_seq=182
dir_binlog=$dir_binlog_182
if [ ! -d $dir_binlog ]; then
        echo "$dir_binlog is not exit and skip!" 
fi
for instance in `ls $dir_binlog`
do
        cd $dir_binlog
        tar -zcf $dir_backup_tar/"$instance_seq""_""$instance"".tar.gz" $instance
        if [ $? -eq 0 ];then
                echo "delete $dir_binlog/$instance/* ..."
                rm -rf $dir_binlog/$instance/*
        else
                echo "tar $dir_binlog/$instance failed!!!"
        fi
done


   


最新手记推荐

• 用composer安装thinkphp框架的步骤• 省市区接口说明• 用thinkphp,后台新增栏目• 管理员添加编辑删除• 管理员添加编辑删除

全部回复(0)我要回复

暂无评论~
  • 取消回复发送
  • php.cn