0

0

MySQL中基于mysqldump和二进制日志log-bin进行逻辑备份以及基于时间点的还原

巴扎黑

巴扎黑

发布时间:2017-06-26 09:12:38

|

1761人浏览过

|

来源于php中文网

原创

 

本文出处: 

 

 

本文仅模拟使用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表中符合idmysqldump -uroot -p -h localhost testdb test_table1 --where "id >  usr/local/mysqlbak/test20170606_2.sql

 

更多mysqldump的参数,参考:

另外,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条数据

  

妙笔工坊
妙笔工坊

妙笔工坊是一个集短剧解说,AI视频生成,口播数字人,小说推文生成的ai智能工具

下载

  然后模拟在某个时间点误删数据的情况,truncate测试表,测试表此时为空

  

  首先利用mysqldump出来的文件还原数据库,mysqldump出来的文件备份是100行时候的数据
  因为备份文件中备份的时候的数据是100行,这里还原之后是100行,没有问题。

  

  然后接着利用log-bin按照时间点还原,上面说了,mysqldump出来的文件记录了日志刷新之后的log-bin的文件名称,
  那么就可以判断日志是否发生了滚动,如果没有滚动,就按照下图最新的log-bin进行按照时间点进行还原。

  

  进行一次mysqldump备份还原
  mysql -u root -p testdb   进然后再行一次基于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来做备份还原了。

 

  

   

  

 

相关专题

更多
php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

5

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

1

2026.01.13

交互式图表和动态图表教程汇总
交互式图表和动态图表教程汇总

本专题整合了交互式图表和动态图表的相关内容,阅读专题下面的文章了解更多详细内容。

15

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

4

2026.01.13

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

5

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 787人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号