mysql全量备份和增量备份方法

文章目录

  • 一、mysql全量备份
    • 1、修改 /etc/my.cnf文件添加如下内容
    • 2、测试任务脚本
    • 3、添加执行脚本
    • 4、天假定时任务
  • 二、mysql增量备份
    • 1、修改 /etc/my.cnf文件添加如下内容
    • 2、重启mysql
    • 3、 添加执行脚本
    • 4、执行恢复
    • 4、测试是否生效

一、mysql全量备份

使用mysqldump 进行全量备份

1、修改 /etc/my.cnf文件添加如下内容

[mysqldump]
user=your_backup_user_name
password=your_backup_passwor

否则会报:Warning: Using a password on the command line interface can be insecure.

2、测试任务脚本

mysqldump -h localhost -uroot -p123456 --flush-logs --databases databaseName > /home/sql/test.sql
# databaseName 备份的数据库
# /home/sql/test.sql 备份的文件路径及文件

3、添加执行脚本

DB_HOST="localhost" DB_NAME="storage" #你要备份的数据库
BIN_DIR="/usr/bin" BCK_DIR="/usr/local/mysql" #备份文件存放的位置 
DATE=`date +%F`
mysqldump -h localhost   --flush-logs  --databases  $DB_NAME > $BCK_DIR/storage_$DATE.sql

4、天假定时任务

定时备份使用linux的 crontab 定时执行任务脚本

0 0 * * * sh /usr/your/path/mysqlBackup.sh

二、mysql增量备份

mysql增量备份需要结合binlog来执行

1、修改 /etc/my.cnf文件添加如下内容

#开启binlog
server_id=2
log_bin=mysql-bin
binlog_format=ROW

[mysqladmin]
user=your_backup_user_name
password=your_backup_password

2、重启mysql

service mysqld restart

3、 添加执行脚本

BakDir=/home/mysql/data      #增量备份时复制mysql-bin.00000*的目标目录,提前手动创建这个目录
BinDir=/var/lib/mysql        #mysql的数据目录
LogFile=/home/mysql/bak.log
BinFile=/var/lib/mysql/mysql-bin.index     #mysql的index文件路径,放在数据目录下
mysqladmin  flush-logs
#这个是用于产生新的mysql-bin.00000*文件
Counter=`wc -l $BinFile |awk '{print $1}'`
NextNum=0
#这个for循环用于比对$Counter,$NextNum这两个值来确定文件是不是存在或最新的
for file in  `cat $BinFile`
do
    base=`basename $file`
 #basename用于截取mysql-bin.00000*文件名,去掉./mysql-bin.000005前面的./
    NextNum=`expr $NextNum + 1`
    if [ $NextNum -eq $Counter ]
    then
        echo $base skip!  >> $LogFile
    else
        dest=$BakDir/$base
        if(test -e $dest)#test -e用于检测目标文件是否存在,存在就写exist!到$LogFile去
        then
            echo  $base exist! >> $LogFile
        else
            cp $BinDir/$base $BakDir
            echo $base copying >> $LogFile
         fi
     fi
done
echo `date +"%Y年%m月%d日 %H:%M:%S"` $Next Bakup succ! >> $LogFile

4、执行恢复

进入到备份的文件路径 即上面配置的 BakDir=/home/mysql/data 执行以下命令
mysqlbinlog mysql-bin.000011 | mysql -u root -p

4、测试是否生效

  1. 执行全量备份脚本
  2. 在数据中随便添加一条数据
  3. 执行增量备份脚本
  4. 删除刚刚添加的数据
  5. 查看 binlog备份路径下的文件
  6. 执行最后一个mysql-bin文件
  7. 查看数据是否已恢复

你可能感兴趣的:(mysql,数据库)