300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > MySQL 技术篇- linux下mysql数据库利用binlog文件进行数据回滚实例演示 binlog恢复

MySQL 技术篇- linux下mysql数据库利用binlog文件进行数据回滚实例演示 binlog恢复

时间:2021-05-03 02:38:13

相关推荐

MySQL 技术篇- linux下mysql数据库利用binlog文件进行数据回滚实例演示 binlog恢复

MySQL 数据库数据回滚

第一章:利用 binlog 进行数据回滚① 查看 binlog 文件所在位置② 查看主数据正在存储数据的 binlog 文件名③ 在控制台查看 binlog 文件内容方法④ 回滚方式一:通过时间点导出 sql 语句⑤ 注意:对比服务器和本地时间算出时间差,避免时间截取错误⑥ 回滚方式二:通过位置点导出 sql 语句⑦ sql 文件恢复方法一: 通过 source 方法恢复数据库⑧ 技巧:筛选导出指定库相关的 sql 脚本⑨ sql 文件恢复方法二: 导入恢复数据库⑩ 技巧:binlog 直接恢复方法

第一章:利用 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=".08.13 18:50:00" --stop-datetime=".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

查看本地时间,可以看到我的本地时间快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, , 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=".08.13 06:50:00" -d ncc_0807mysql --stop-datetime=".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

喜欢的点个赞❤吧!

MySQL 技术篇- linux下mysql数据库利用binlog文件进行数据回滚实例演示 binlog恢复数据库的两种方式

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。