MySQL增量備份的指令碼(innobackupex)

luashin發表於2016-03-10
#!/bin/sh
#author RuM
#date 2015-07-10
BAKDIR=/tmp/mysqlbak
BAKDIR_FULL=$BAKDIR/full
BAKDIR_ADD=$BAKDIR/add
CONF=/etc/my.cnf
PASSWD=123456
INNOBACKUPEX=/usr/bin/innobackupex

#第一次執行會做一次全備跟增備,以後執行都會是增量備份
if [ -f "$INNOBACKUPEX" ]
    then
        if  [ -d "$BAKDIR" ]
        then
   echo "is ok"
        else
   mkdir $BAKDIR_FULL -p
   mkdir $BAKDIR_ADD -p
  fi
####全備
files=`ls $BAKDIR_FULL`
  if [ -z "$files" ]
   then
    $INNOBACKUPEX  --defaults-file=$CONF  --user=root --password=$PASSWD  $BAKDIR_FULL
    FULLNAME=$(dir "$BAKDIR_FULL")
    $INNOBACKUPEX  --defaults-file=$CONF  --user=root --password=$PASSWD --incremental-basedir=$BAKDIR_FULL/$FULLNAME/ --incremental $BAKDIR_ADD
   else
####增量備份
    ADDNAME=$(ls -lt $BAKDIR_ADD |sed -n 2p|awk '{print $9}')
    $INNOBACKUPEX  --defaults-file=$CONF  --user=root --password=$PASSWD --incremental-basedir=$BAKDIR_ADD/$ADDNAME/ --incremental $BAKDIR_ADD
  fi
 else
  echo "is not install innobackupex"
fi

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/9034054/viewspace-2054799/,如需轉載,請註明出處,否則將追究法律責任。

相關文章