mysqlのbinlogログの自動パッケージング


一、需要
オンラインの1台の機械は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