采用binlog日志的好处
  掌控所有更改操作,必要时可用于恢复数据
  数据库主从复制的必要条件

  1. [linyouyi@localhost~]# vim /etc/my.cnf
  2. [mysqld]
  3. .. ..
  4. log-bin=mysql-bin //启用二进制日志,并指定前缀
  5. .. ..
    [linyouyi@dbsvr1 ~]# service mysqld restart

确认binlog日志文件
新启用binlog后,每次启动MySQl服务都会新生成一份日志文件:

  1. [linyouyi@localhost~]# ls /var/lib/mysql/mysql-bin.*
  2. /var/lib/mysql/mysql-bin. /var/lib/mysql/mysql-bin.index

清除binlog日志
  删除早前指定版本的binlog日志
    RURGE MASTER LOGS TO "binlog日志"
  删除所有binlog日志,重新新建日志
    RESET MASTETR

分析binlog日志
  使用mysqlbinlog工具
    格式:mysqlbinlog [选项] 日志文件
  常用选项
    --start-datatime="YYYY-mm-dd HH:MM:SS"
    --stop-datatime="YYYY-mm-dd HH:MM:SS"
    --start-position=起止位置
    --stop-positon=结束位置

  1. [linyouyi@localhost ~]# mysqlbinlog /var/lib/mysql/mysql-bin.
  2. [linyouyi@localhost ~]# mysqlbinlog --start-datetime="2018-10-20 23:30" /var/lib/mysql/mysql-bin.

利用binlog恢复数据
  基本方法
    使用mysqlbinlog提取历史SQL操作
    通过管道交给mysql命令重做
  案例
    重做第一份binlog所记录的更改操作
执行指定Pos节点范围内的sql命令恢复数据
根据上述日志分析,只要恢复从2018-10-12 20:40:50到2018-10-20 23:15:50之间的操作即可。可通过mysqlbinlog指定时间范围输出,结合管道交给msyql命令执行导入重做:

  1. [linyouyi@loclahost ~]# mysqlbinlog \
  2. --start-datetime="2018-10-12 20:40:50" \
  3. --stop-datetime="2018-10-20 23:15:50" \
  4. /var/lib/mysql/mysql-bin. | mysql -u linyouyi -p
  5. Enter password:
  6. 若是全部重做
  7. [linyouyi@loclahost ~]# mysqlbinlog /var/lib/mysql/mysql-bin. | mysql -u linyouyi -p
  8. Enter password:

mysql备份工具
  mysqlhotcopy不足
    仅适用于MyISAM引擎的数据库
    备份过程中,数据插入和更新操作都会被挂起
  mysqldump不足
    效率较低,备份和还原速度慢
    备份过程中,数据插入和更新操作会被挂起
  XtraBackup工具
    在线热备份工具
    备份过程中不锁表,适合生产环境适用
    支持整体备份和增量备份
    组件一xtrabackup:C程序,支持InnoDB和XtraDB,不能备份数据表结构
    组件二innobackupex:以Perl脚本封装xtrabackup,还支持MyISAM,能备份数据表结构

xtrabackup基本选项
基本选项 解释
--backup 执行备份操作
--target-dir 备份到目标文件夹
--datadir 备份的原始文件夹(Mysql库的位置)
--prepare 准备恢复数据
--increamental-basedir 增量备份时,指定参照的完整备份路径
--incremental-dir 准备恢复目录时,指定增量备份的路径

1)使用XtraBackup执行数据库备份

  1. [linyouyi@localhost~]# mkdir -p /backup/mysql
  2. [linyouyi@localhost~]# xtrabackup_56 backup --datadir=/var/lib/mysql/ --target-dir=/backup/mysql/

2)确认备份好的文件数据:

  1. [linyouyi@loclahost~]# ls /backup/mysql/

3)做一个增量备份(基于前一步的完整备份)

  1. [linyouyi@localhost ~]# xtrabackup_56 --backup \ #xtrabackup_55 是5.5版本,xtrabackup_56是5.6版本
  2. --datadir=/var/lib/mysql/ \
  3. --target-dir=/backup/inc01/ \
  4. --incremental-basedir=/backup/mysql/

确认备份好的文件数据:

  1. [linyouyi@localhost~]# ls /backup/inc01/

对比完整备份、增量备份的大小:

  1. [linyouyi@localhost~]# du -sh /backup/mysql/ /backup/inc01/
  2. 11M /backup/mysql/ //完整备份的大小
  3. 264K /backup/inc01/

准备用于恢复的数据库目录
以/backup/mysql/可用来重建MySQL服务器。这种情况下,官方建议连做两次--prepare,以确保数据一致性:

  1. [linyouyi@localhost ~]# xtrabackup_56 --prepare --target-dir=/backup/mysql/
  2. [linyouyi@localhost ~]# xtrabackup_56 --prepare --target-dir=/backup/mysql/

准备恢复“完整备份+增量备份”

以/backup/mysql/用来重建MySQL服务器,但这种情况下需提前合并相关增量备份的数据:
先准备完整备份目录,添加--apply-log-only仅应用日志:

  1. [linyouyi@loclahost ~]# xtrabackup_56 --prepare --target-dir=/backup/mysql --apply-log-only

然后整合增量备份的数据,通过--incremental-dir选项指定增量位置:

  1. [linyouyi@localhost ~]# xtrabackup_56 --prepare \
  2. --target-dir=/backup/mysql --apply-log-only \
  3. --incremental-dir=/backup/inc01

至此,已经把全量备份和增量备份合并了

接着停止数据库,删除/var/lib/mysql/下的内容,拷贝数据

  1. [linyouyi@localhost home]# systemctl stop mariadb
  2. //删除/var/lib/mysql/下的内容
  3. [linyouyi@localhost home]# rm -rf /var/lib/mysql/*
  4. #[linyouyi@hadoop01 home]# innobackupex --defaults-file=/etc/my.cnf --copy-back /home/mysql --user=linyouyi --password=123456
  5. [linyouyi@localhost home]# xtrabackup --copy-back --target-dir=/home/mysql
  6. [linyouyi@localhost home]# chown -R mysql:mysql /var/lib/mysql/
  7. [linyouyi@localhost home]# systemctl start mariadb

至此,数据已经恢复成功

mysql实时增量备份的更多相关文章

  1. MYSQL数据库增量备份

    MySQL数据库增量备份,在这之前修改我们的数据库配置文件/etc/my.cnf开启bin-log日志功能即可.接下来是我参考了下网上的一些方法,自己写的,主要还是要能学到他的一些思路和方法. #fu ...

  2. NFS +inotify+rsync 实现数据的远程挂载与实时增量备份

    NFS 网络文件系统 功能: 用户可以像访问自己的本地文件系统一样使用网络中的远端系统上的文件 原理: 用户进程-->RPC服务(portman)-->tcp/ip协议栈-->远端主 ...

  3. 通过innobackupex实现对MySQL的增量备份与还原

    备份 增量备份是基于完整备份的,所以我们需要先做一次完整备份: innobackupex --password=test /backup/ 备注:test是我的MySQL服务的root用户的密码,/b ...

  4. mysql 二进制文件增量备份

    1.首先在my.cnf下添加二进制文件路径(windows下文件名称为my.ini) 在[mysqld]下添加 log-bin=mysql-bin 2.centos下默认安装mysql 5.6,数据默 ...

  5. Python 生产环境MySQL数据库增量备份脚本

    MySQL数据库常用的办法是通过MySQLdump导出sql进行备份,但是不适合数据量很大的数据库,速度,锁表是两个严重的问题.前面写了一遍文章介绍xtrabackup的热备工具,见 http://w ...

  6. mysql实现增量备份

    有点要注意 如果你误删了表 想通过这个恢复 必须恢复日志里面有创建表的日志 不然的话是无法回复的  就是必须是从你开始创建表的时候就已经记录日志了  恢复到哪个位置 就按照哪个位置来计算 mysql ...

  7. mysql xtrabackup增量备份

    mysql 增量备份策略 周一全备,其他增量备份,根据业务需要,设定保留日期,如保留一月. 增量备份步骤; 1 创建全备 2 根据全备目录,创建增量备份 3 第二次增量备份根据第一次增量备份目录,依次 ...

  8. mysql的增量备份与全备的脚本

    mysql全量备份.增量备份.开启mysql的logbin日志功能.在/etc/my.cnf文件中加入以下代码: [mysqld]log-bin = "/home/mysql/logbin. ...

  9. innobackupex实现对MySQL的增量备份与还原

    备份增量备份是基于完整备份的,所以我们需要先做一次完整备份: innobackupex --defaults-file=/etc/my.cnf --user root --password cheng ...

随机推荐

  1. ABBYY PDF Transformer+系统要求

    ABBYY PDF Transformer+是一个新的,全面的巧妙解决PDF文档的工具,它将泰比的光学字符识别(OCR)技术和Adobe®PDF技术完美结合,以确保实现便捷地处理任何类型的PDF文件, ...

  2. SpringBoot Docker Mysql安装,Docker安装Mysql

    SpringBoot Docker Mysql安装,Docker安装Mysql ================================ ©Copyright 蕃薯耀 2018年4月8日 ht ...

  3. jquery-ui弹框登录前端写法

    新建一个div: <div class="container" id="loginForm" hidden> <h4 class=" ...

  4. 【死磕jeesite源码】mybatis动态调用表名和字段名

    本文转载自夏雪冬日 一直在使用Mybatis这个ORM框架,都是使用mybatis里的一些常用功能.今天在项目开发中有个业务是需要限制各个用户对某些表里的字段查询以及某些字段是否显示,如某张表的某些字 ...

  5. NLP入门资料

    <统计自然语言处理> 一些基础理论概念,涉及统计自然语言处理的基本概念.理论方法和新研究进展,内容包括形式语言与自动机及其在自然语言处理中的应用.语言模型.隐马尔可夫模型.语料库技术.汉语 ...

  6. 7.11登入表单html

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  7. php链式操作的实现

    );//$db->where("id=1");//$db->where("name=2");//$db->order("id des ...

  8. [转] - Spark排错与优化

    Spark排错与优化 http://blog.csdn.net/lsshlsw/article/details/49155087 一. 运维 1. Master挂掉,standby重启也失效 Mast ...

  9. [No0000CF]想有一辈子花不完的钱?从了解“被动收入”开始吧

    我想从理清自己所说被动收入的含义,开始创作此被动收入系列文章. 我更喜欢把被动收入较宽泛地定义为,甚至当你没有主动工作时,仍可赚取的收益.被动收入的另一个名称是剩余收入. 相比之下,当你停止工作时,通 ...

  10. /etc/apt/sources.list" E212: Can't open file for writing解决方案

    :w !sudo tee % > /dev/null 解决.