MySQL 技术篇- linux下mysql数据库利用binlog文件进行数据回滚实例演示,binlog恢复数据库的两种方式
发布日期:2021-06-30 16:45:16
浏览次数:2
分类:技术文章
本文共 3046 字,大约阅读时间需要 10 分钟。
MySQL 数据库数据回滚
第一章:利用 binlog 进行数据回滚
① 查看 binlog 文件所在位置
首先通过下面的语句查看 binlog 文件所在位置。
show variables like '%log_bin%';
可以看到位置是 /usr/local/mysql-8.0.11/data/
② 查看主数据正在存储数据的 binlog 文件名
查看 show master status
可以定位到目前正在存储数据的是 binlog.000025
③ 在控制台查看 binlog 文件内容方法
通过 bin 下面的 mysqlbinlog 工具来看法 binlog 文件,可以看到都记录了什么。
[root@localhost bin]# "/usr/local/mysql-8.0.11/bin/mysqlbinlog" --no-defaults "/usr/local/mysql-8.0.11/data/binlog.000025"
④ 回滚方式一:通过时间点导出 sql 语句
看一下误删的时间。 通过中间时间点导出 sql 语句,现在是有一定时间差的,因为本地时间和服务器时间不同步,下一节说明怎么计算时间差。
[root@localhost bin]# "/usr/local/mysql-8.0.11/bin/mysqlbinlog" --no-defaults --start-datetime="2020.08.13 18:50:00" --stop-datetime="2020.08.13 18:55:00" "/usr/local/mysql-8.0.11/data/binlog.000025" > 0813.sql
⑤ 注意:对比服务器和本地时间算出时间差,避免时间截取错误
查看服务器时间。
[root@localhost bin]# dateThu Aug 13 07:44:36 EDT 2020
查看本地时间,可以看到我的本地时间快8分钟左右,截取日志的时候要看提前 8 分钟的内容。
⑥ 回滚方式二:通过位置点导出 sql 语句
首先看两个恢复点中间的位置信息。 上面是通过两个时间点截取,这个是通过两个位置点截取。 通过指定位置导出数据库。
[root@localhost mysql-8.0.11]# "/usr/local/mysql-8.0.11/bin/mysqlbinlog" --no-defaults --start-position=204590 -d ncc_0807mysql --stop-position=252554 "/usr/local/mysql-8.0.11/data/binlog.000025" > 0815.sql
⑦ sql 文件恢复方法一: 通过 source 方法恢复数据库
登录数据库、切换数据库、恢复数据库。
[root@localhost ~]# "/usr/local/mysql-8.0.11/bin/mysql" -uroot -p123456 -Amysql: [Warning] Using a password on the command line interface can be insecure.Welcome to the MySQL monitor. Commands end with ; or \g.Your MySQL connection id is 41Server version: 8.0.11 MySQL Community Server - GPLCopyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or itsaffiliates. Other names may be trademarks of their respectiveowners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql> show databases;+--------------------+| Database |+--------------------+| information_schema || mysql || ncc_0807auto || ncc_0807mysql || performance_schema || sys |+--------------------+6 rows in set (0.01 sec)mysql> use ncc_0807mysql;Database changedmysql> source /usr/local/mysql-8.0.11/bin/0813.sql;Query OK, 0 rows affected (0.00 sec)Query OK, 0 rows affected (0.00 sec)Query OK, 0 rows affected (0.00 sec)Query OK, 0 rows affected (0.01 sec)
⑧ 技巧:筛选导出指定库相关的 sql 脚本
指定数据库:-d 数据库名,或 –database= 数据库名。
[root@localhost mysql-8.0.11]# "/usr/local/mysql-8.0.11/bin/mysqlbinlog" --no-defaults --start-datetime="2020.08.13 06:50:00" -d ncc_0807mysql --stop-datetime="2020.08.13 06:55:00" "/usr/local/mysql-8.0.11/data/binlog.000025" > 0814.sql
⑨ sql 文件恢复方法二: 导入恢复数据库
导入恢复数据库。
[root@localhost mysql-8.0.11]# "/usr/local/mysql-8.0.11/bin/mysql" -uroot -p123456 ncc_0807mysql < "/usr/local/mysql-8.0.11/0814.sql"
⑩ 技巧:binlog 直接恢复方法
位置的直接 binlog 恢复库方法。 直接恢复,无需中转。
[root@localhost mysql-8.0.11]# "/usr/local/mysql-8.0.11/bin/mysqlbinlog" --no-defaults --start-position=204590 --stop-position=252554 "/usr/local/mysql-8.0.11/data/binlog.000025" | "/usr/local/mysql-8.0.11/bin/mysql" -uroot -p123456
喜欢的点个赞❤吧!
转载地址:https://lanzao.blog.csdn.net/article/details/107989565 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
第一次来,支持一个
[***.219.124.196]2024年04月16日 21时27分28秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
JAVA学习笔记4 - 循环与分支结构
2019-04-30
JAVA学习笔记6 - 数组
2019-04-30
JAVA学习笔记8 - Stream 和 File I/O
2019-04-30
JAVA学习笔记9 - 异常
2019-04-30
JAVA学习笔记10 - 继承
2019-04-30
JAVA学习笔记11 - 接口interface
2019-04-30
JAVA学习笔记12 - 包package
2019-04-30
Android 开发学习笔记 00 - Getting Started
2019-04-30
【学习笔记】Android Activity
2019-04-30
【学习笔记】Android Fragments
2019-04-30
Android使用Retrofit_00_Getting Started
2019-04-30
Android使用Retrofit_01_OAuth2 + GitHub
2019-04-30
Django + REST学习笔记
2019-04-30
【转载】将Ubuntu16.04 中gedit在仅显示一个文件时显示文件名tab
2019-04-30
fstream 对象多次使用时注意clear
2019-04-30