设为首页 收藏本站
查看: 460|回复: 0

[经验分享] 从机上的MySQL备份脚本

[复制链接]

尚未签到

发表于 2018-10-3 12:41:42 | 显示全部楼层 |阅读模式
#!/bin/bash  

  

  
CFGFILE=/etc/my.cnf                           ##
  
BINFILE=$(gawk -F'[ \t]*=[ \t]*' '$1~/log[-_]bin$/{print $2}' $CFGFILE | grep ${0#*_})
  
#BINDIR=${BINFILE%/*}
  
BINPREFIX=${BINFILE##*/}
  

  
DATEFORMAT="date +'%Y-%m-%d %H:%M:%S'"
  

  
LOGERROR_PREFIX="[ERROR   \`$DATEFORMAT\` ] :"
  
LOGPROCESS_PREFIX="[PROCESS \`$DATEFORMAT\` ] :"
  
LOGSUCCESS_PREFIX="[SUCCESS \`$DATEFORMAT\` ] :"
  

  
BAKDIR=/backup/pharmbk/db222/incebak            ##
  
FULLBAKDIR=/backup/pharmbk/db222/fullbak        ##
  
LOGFILE=$BAKDIR/baklog
  
POINTFILE=$BAKDIR/pointfile
  
DUMPFILE=InnoDBexport
  
DATAPOCESS=0
  
OSUSER=backupme                               ##
  
OSGROUP=admins                                ##
  

  

  
USER=backupme
  
PASS=12345
  
SOCK=/var/lib/mysql/prods/db222/mysql.sock
  
PORT=3306
  

  
if echo "$BINFILE" | grep -q '/';then
  
        BINDIR=${BINFILE%/*}
  
else
  
        BINDIR=$(mysql -u$USER -p$PASS -S$SOCK -ss -e "show variables like 'datadir'" | awk '{print $2}')
  
fi
  

  
if [ ! -e $BAKDIR -o ! -d $BAKDIR ]
  
then
  
        mkdir -p $BAKDIR
  
fi
  

  
MYSQLARG="mysql -u$USER -p$PASS -S$SOCK"
  
MYSQLDUMPARG="mysqldump -u$USER -p$PASS -S$SOCK"
  

  
# only do rsync op
  

  
if [ $# -eq 1 ]
  
then
  
        if [ "$1" == "rsync" -a -e "$FULLBAKDIR" ]
  
        then
  
                eval echo "$LOGPROCESS_PREFIX do rsync on `date`" >> $LOGFILE
  
        echo "sudo rsync -av --include=$BINPREFIX.* --exclude=* $BINDIR/ $BAKDIR/" >> $LOGFILE
  
          #这里--include 和--exclude都不能加绝对路径.
  
                sudo rsync -av --include=$BINPREFIX.* --exclude=* $BINDIR"/" $BAKDIR"/" >> $LOGFILE 2>&1
  
                exit
  
        else
  
                        eval echo "$LOGERROR_PREFIX full backup not done,do it first!" >> $LOGFILE
  
                        exit
  
        fi
  
                        eval echo "$LOGERROR_PREFIX unrecognize args ,plz check again!" >> $LOGFILE
  
                        exit
  
fi
  

  
#if [ ! -e "$FULLBAKDIR" ]
  
#then
  
#       eval echo "$LOGERROR_PREFIX full backup not start,do not rsync bin log!" >> $LOGFILE
  
#        exit
  
#fi
  

  
echo "****************************" >> $LOGFILE
  
eval echo "$LOGPROCESS_PREFIX $0: start backup on `date`" >> $LOGFILE
  

  
# stop slaver
  

  
eval echo "$LOGPROCESS_PREFIX stop slave " >> $LOGFILE
  
stop_slave=$MYSQLARG" -e 'stop slave'"
  
#注意
  
echo "$stop_slave"|sh
  

  
# sleep for a while
  

  
sleep 10
  

  
# record the pointer
  

  
eval echo "$LOGPROCESS_PREFIX write binlog pointer" >> $LOGFILE
  
#注意-ss参数
  
pointer=$(eval $MYSQLARG" -ss -e 'show master status'"|awk -F'[.\t ]' '{print $2}')
  
echo $(date +%Y%m%d) ${pointer} >> $POINTFILE
  

  
# flush log闭当前的二进制日志文件并创建一个新文件,
  
#  新的二进制日志文件的名字在当前的二进制文件的编号上加1。
  
eval echo "$LOGPROCESS_PREFIX switch binlog to next" >> $LOGFILE
  
flush_logs=$MYSQLARG" -e 'flush logs'"
  
echo "$flush_logs"|sh
  

  
# rsync binlog to bakdir (remove binlong file in BAKDIR which not exist in BINDIR)
  

  
eval echo "$LOGPROCESS_PREFIX rsync binlog to $BAKDIR" >> $LOGFILE
  
sudo rsync -av --delete-before --include=$BINPREFIX.* --exclude=* $BINDIR"/" $BAKDIR"/" >> $LOGFILE 2>&1
  

  
if [ $? -eq 0 ]
  
then
  
        eval echo "$LOGSUCCESS_PREFIX rsync success" >> $LOGFILE
  
else
  
        eval echo "$LOGERROR_PREFIX rsync file failed" >> $LOGFILE
  
fi
  

  
# see if the first day of this month
  

  
if [ $(date +%d) == "04" ]
  
then
  
# do full backup
  

  
eval echo "$LOGPROCESS_PREFIX do full backup" >> $LOGFILE
  
DATAPOCESS=1
  
CURRENTDIR=`date +%Y%m`
  

  
        if [ ! -e $FULLBAKDIR -o ! -d $FULLBAKDIR ]
  
        then
  
                 mkdir -p $FULLBAKDIR
  
        fi
  

  
        if [ ! -e $FULLBAKDIR/$CURRENTDIR -o ! -d $FULLBAKDIR/$CURRENTDIR ]
  
        then
  
                mkdir -p $FULLBAKDIR/$CURRENTDIR
  
        fi
  

  
        db_list=$MYSQLARG" -e 'show schemas'"
  

  
        for db in `echo "$db_list"|sh|sed '1d;/information_schema/d;/performance_schema/d;'`
  
        do
  
                eval echo "$LOGPROCESS_PREFIX Begin backup $db to $FULLBAKDIR/$CURRENTDIR" >> $LOGFILE
  
                sudo mysqlhotcopy -u $USER -p $PASS -S $SOCK $db $FULLBAKDIR/$CURRENTDIR >> $LOGFILE 2>&1
  

  
                if [ $? -eq 0 ]
  
                then
  
                          eval echo "$LOGSUCCESS_PREFIX Backup $db finish" >> $LOGFILE
  
                else
  
                          eval echo "$LOGERROR_PREFIX can not backup $db" >> $LOGFILE
  
                fi
  

  
         done
  

  
# remove files belong to innodb
  

  
        SQL="select CONCAT(TABLE_SCHEMA,'.',TABLE_NAME) FROM INFORMATION_SCHEMA.\
  
                TABLES WHERE ENGINE='InnoDB'"
  
#$MYSQLARG -ss -e "$SQL" \
  
#| while read L
  
        exec 3<  $LOGFILE
  
                \rm $FULLBAKDIR/$CURRENTDIR/$DB/"$TABLE."*
  

  
# dump this table
  
                eval echo "$LOGPROCESS_PREFIX export table $TABLE" >> $LOGFILE
  
                $MYSQLDUMPARG --add-drop-table --single-transaction --opt --quick -B $DB --tables "$TABLE" >> $FULLBAKDIR/$CURRENTDIR/$DUMPFILE_$DB.sql
  

  
        done
  

  
# keep one full backup,so if last full backup data exist,remove it from backup directory after new full backup finish
  

  
        LASTDIR=`date +%Y%m -d '1 month ago'`
  
        if [ -d $FULLBAKDIR/$LASTDIR ]
  
        then
  
                eval echo "$LOGPROCESS_PREFIX remove $LASTDIR backup data from disk" >> $LOGFILE
  
                cd $FULLBAKDIR && rm -rf $LASTDIR
  
        else
  
                eval echo "$LOGPROCESS_PREFIX no last backup data exist" >> $LOGFILE
  
        fi
  

  
fi
  

  
# start slave
  

  
eval echo "$LOGPROCESS_PREFIX restart slave " >> $LOGFILE
  
start_slave=$MYSQLARG" -e 'start slave'"
  
echo "$start_slave"|sh
  

  
eval echo "$LOGPROCESS_PREFIX end backup at `date`" >> $LOGFILE
  

  
if [ $DATAPOCESS -eq 1 ]
  
then
  
eval echo "$LOGPROCESS_PREFIX begin process backup data at `date`" >> $LOGFILE
  

  
# change bak dir owner ,so rm can operate normally
  
sudo /bin/chown -R $OSUSER.$OSGROUP $FULLBAKDIR
  

  
# zip backup data
  
        eval echo "$LOGPROCESS_PREFIX zip data in $FULLBAKDIR/$CURRENTDIR" >> $LOGFILE
  
        cd $FULLBAKDIR/$CURRENTDIR && \
  
        for db in *
  
        do
  
                sudo tar zvcf $db.tar.gz $db >> $LOGFILE 2>&1
  
                rm -rf $db
  
        done
  

  
        if [ $? -eq 0 ]
  
        then
  
                eval echo "$LOGSUCCESS_PREFIX zip done successfully" >> $LOGFILE
  
        else
  
                eval echo "$LOGERROR_PREFIX error happen in zip data" >> $LOGFILE
  
                exit 1
  
        fi
  

  
# change bak dir owner ,so rm can operate normally
  
sudo /bin/chown -R $OSUSER.$OSGROUP $FULLBAKDIR
  

  
fi
  

  
## END



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-609592-1-1.html 上篇帖子: MySQL DDL操作--------视图最佳实战 下篇帖子: mysql 基于 ssl 的主从复制
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表