MySQL中基于mysqldump和二进制日志log-bin进行逻辑备份以及基于时间点的还原
本文出处:http://www.cnblogs.com/wy123/p/6956464.html
本文仅模拟使用mysqldump和log-bin二进制日志进行简单测试,仅作为个人学习笔记,可能离实际应用还有很大差距,仅参考。
开启MySQL的bin-log二进制日志
模拟还原是需要mysqldump出来的文件和log-bin,因此需要开始log-bin二进制日志。
mysql5.7.18在开启二进制日志的时候除了要设置log-bin的位置之外,另外需要设置一个server-id,MySQL之前的版本应该不需要这个设置。
吐槽一下开源软件,基本上每个版本都有一些跟之前版本不一样的地方,网上查资料往往不好使,不同版本的情况下不少东西都是不一样的,这一点需要注意。
重启之后,查询log_bin相关的变量
mysqldump备份(导出)数据的基本使用
mysqldump命令参数相当多,简单记录一下常用的命令,以及利用mysqldump备份(严格说是导出数据)和二进制日志log-bin进行数据库还原操作。
-- 备份testdb整个数据库,-l 表示给所有表上加一个读锁,-F (F要大写,小写不报错单页无效)表示滚动生成一个新的日志文件
mysqldump -u root -p -l -F -h localhost testdb > usr/local/mysqlbak/test20170607_data.sql
备份出来的文件就是create table和insert into table的脚本
-- 备份testdb数据库中的test_table1 test_table2两张表,加上--no-create-info就意味这个备份出来的文件不带create table的脚本,仅仅是insert into table的信息
mysqldump -uroot -p -h localhost testdb test_table1 test_table2 --no-create-info> usr/local/mysqlbak/test20170606_1.sql
-- 备份testdb数据库中的test2表中的一部分数据,也就是备份test_table1表中符合id<1000的数据
mysqldump -uroot -p -h localhost testdb test_table1 --where "id<1000" > usr/local/mysqlbak/test20170606_2.sql
更多mysqldump的参数,参考:http://www.cnblogs.com/xuejie/archive/2013/01/11/2856911.html
另外,mysql log-bin的更换策略:
使用索引来循环文件,在以下条件将循环至下一个索引
1。服务器重启
2。服务器被更新
3。日志到达了最大日志长度 max_binlog_size
4。日志被刷新 mysql> flush logs;
利用mysqldump备份的文件和log-bin二进制日志进行还原
首先在以表中有数据的情况下进行备份
执行 mysqldump -u root -p -l -F -h localhost testdb --master-data=2 > usr/local/mysqlbak/test20170607_data.sql
这里加了一个--master-data=2的选项,目的是在备份文件中备注出来当前的log_bin的文件,
至于为什么要加这个命令,很多博客上都记录的是用mysqldump备份出来一个文件之后,修改数据,然后模拟数据库误删或者宕机还原怎么的,然后在使用mysqldump出来的文件还原之后,接着使用log-bin还原
虽然都是测试模拟,但是有一个明显的问题啊,怎么知道mysqldump之后日志是否发生了滚动,滚动了几次?
如果日志不滚动还要,按照时间点或者位置还原log-bin文件,如果滚动了,怎么知道滚动了几个日志文件呢
就需要在mysqldump执行的时候,记录下来刷新日志之后的新生成的log-bin文件,在使用日志还原的时候,才能判断使用哪些日志进行还原。
有了--master-data=2的选项,才知道mysqldump备份时候的log_file位置
然后继续往表中插入10条数据
然后模拟在某个时间点误删数据的情况,truncate测试表,测试表此时为空
首先利用mysqldump出来的文件还原数据库,mysqldump出来的文件备份是100行时候的数据
因为备份文件中备份的时候的数据是100行,这里还原之后是100行,没有问题。
然后接着利用log-bin按照时间点还原,上面说了,mysqldump出来的文件记录了日志刷新之后的log-bin的文件名称,
那么就可以判断日志是否发生了滚动,如果没有滚动,就按照下图最新的log-bin进行按照时间点进行还原。
进行一次mysqldump备份还原
mysql -u root -p testdb < usr/local/mysqlbak/test20170607_data.sql
进然后再行一次基于bin-log的时间点还原
mysqlbinlog --stop-datetime="2017-6-7 21:45:00" /var/lib/mysql/mysql-bin.000022 | mysql -u root -p testdb
然后数据就回来了。
当然这里仅仅是模拟操作,当然还有许多细节尚未确定,如果发生了日志滚动,要做基于时间点的还原,还要追究到究竟是基于哪个日志文件的时间点。
总结:
本文仅仅以一个简单的示例来模式数据库的还原操作,
mysqldump备份模式比较简单粗暴,仅仅是将数据导出为insert脚本,在还原较大数据时候会有性能问题,可能mysqldump就不适合了,就需要更为高效的xtrabackup来做备份还原了。
MySQL中基于mysqldump和二进制日志log-bin进行逻辑备份以及基于时间点的还原的更多相关文章
- MySQL中几种常见的日志
前言: 在 MySQL 系统中,有着诸多不同类型的日志.各种日志都有着自己的用途,通过分析日志,我们可以优化数据库性能,排除故障,甚至能够还原数据.这些不同类型的日志有助于我们更清晰的了解数据库,在日 ...
- 如何开启MySQL 5.7.12 的二进制日志
1. 打开/etc下的my.cnf文件 2. 编辑它,添加内容: log_bin=binary-log #二进制日志的文件名 server_id=1 #必须指定server_id,这是MySQL ...
- MySql中innodb存储引擎事务日志详解
分析下MySql中innodb存储引擎是如何通过日志来实现事务的? Mysql会最大程度的使用缓存机制来提高数据库的访问效率,但是万一数据库发生断电,因为缓存的数据没有写入磁盘,导致缓存在内存中的数据 ...
- Mysql中使用mysqldump进行导入导出sql文件
纪念工作中的第一次删库跑路的经历 今天接到一个任务,是将一个测试库数据导到另一个测试库,然而我们公司的数据库是不让直连的,所以只能通过远程连接进行导库操作. 老大布置任务的时候让用dump命令进行操作 ...
- mysql主从复制linux配置(二进制日志文件)
安装mysql,两台机器一主(192.168.131.153),一从(192.168.131.154) 主机配置 修改主/etc/my.cnf文件 添加 #server_id=153 ###服务器id ...
- MySQL复制(二)--基于二进制日志文件(binlog)配置复制
基础环境: 主库 从库 服务器IP地址 192.168.10.11 192.168.10.12 版本 5.7.24 5.7.24 已存在的数据库 mysql> show databases; ...
- MySQL二进制日志(binary log)总结
本文出处:http://www.cnblogs.com/wy123/p/7182356.html (保留出处并非什么原创作品权利,本人拙作还远远达不到,仅仅是为了链接到原文,因为后续对可能存在的一些错 ...
- mysql错误日志/var/log/mariadb/mariadb.log,二进制日志
mariadb-日志 IT_luo关注0人评论65人阅读2018-10-15 08:59:03 mariadb日志 mariadb日志: 1.查询日志:query log: 2.慢查询日志:slo ...
- MySQL基于二进制日志的主从复制
一.什么是MySQL的主从复制? MySQL可以将一个数据库设置为主库,另一个数据库设置为该主库的从库,当主库发生了变更,会同步到从库中.MySQL的主从架构,可以是星型的,也可以是线型的. 星型架构 ...
随机推荐
- 莫烦tensorflow(6)-tensorboard
import tensorflow as tfimport numpy as np def add_layer(inputs,in_size,out_size,n_layer,activation_f ...
- XQuery:查询任何可作为 XML 形态呈现的数据,包括数据库
XQuery 也被称为 XML Query,被设计用来查询 XML 数据. 学习这个 需要知道 HTML / XHTML XML / XML 命名空间 XPath XML 实例文档 我们将在下面的例子 ...
- 慢工出细活 JS 等待加载效果
实例可以直接运行查看效果.很方便快捷 <html> <head> <meta http-equiv="content-Type" content=&q ...
- PythonStudy——机器语言 Machine Language
编程语言 编程语言(programming language),是用来定义计算机程序的形式语言.它是一种被标准化的交流技巧,用来向计算机发出指令.一种计算机语言让程序员能够准确地定义计算机所需要使用的 ...
- php微服务框架 PHP-MSF 的容器部署和使用
评论:1 · 阅读:8412· 喜欢:1 一.需求 PHP-msf 是 Carema360 开发的 PHP 微服务框架,目前我没有实际用过,但是市面上的微服务框架要么在推崇 Spring 系,要么是 ...
- Delphi2009之TImage
TPngImage原来是SourceFroge上的一个开源项目,现在突然消失了,为什么呢?Nick 在他的博客上写到:TPNGImage被CodeGear/Embarcadero收购了,现在直接就是D ...
- Windows IIS安装php
[可参考文档:https://docs.microsoft.com/en-us/iis/application-frameworks/scenario-build-a-php-website-on-i ...
- 将Long类型转为字母数字组合的jar包---Hashids
在设计数据库时,我有时喜欢使用自增Id,而不是uuid,但是在面对终端用户时,直接暴露id不是一个好的行为. 经过查询,可以使用 Hashids 这个jar包将id转为类似YouTube的大小写字母和 ...
- 利用MYSQL的函数实现用户登录功能,进出都是JSON(第一版)
以HMAC密钥形式发放密钥令牌 功能如下 1:记录用户的登录的IP地址.时间 2:实现密码错误次数超限后锁定,并提示何时解锁 CREATE DEFINER=`root`@`%` FUNCTION `u ...
- linux关于 文件/文件夹的操作 中
说一个关于stat函数 stat函数 表头文件: #include <sys/stat.h> 函数定义: int stat(const char *file_name, str ...