MySQL增量备份实现方法- 梦里云
基础教程 2025-10-09 05:45 91

所谓增量备份,就是备份自上一次备份之后增加或改变的文件或内容。然而MySQL没有提供直接的增量备份方法,本篇文章为大家分享一下MySQL增量备份实现方法。

添加自动任务每小时或者更短时间执行就好了

#!/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

Powered by ©智简魔方