Mysql误操作后利用binlog2sql快速回滚的方法详解
发布时间 - 2026-01-11 02:18:50 点击率:次前言

在日常工作或者学习中,操作数据库时候难免会因为“大意”而误操作,需要快速恢复的话通过备份来恢复是不太可能的,下面这篇文章主要给大家介绍关于Mysql误操作后利用binlog2sql快速回滚的方法,话不多说,来一起看看详细的介绍:
一、总体解释:
DML(data manipulation language):
它们是SELECT、UPDATE、INSERT、DELETE,就象它的名字一样,这4条命令是用来对数据库里的数据进行操作的语言
DDL(data definition language):
DDL比DML要多,主要的命令有CREATE、ALTER、DROP等,DDL主要是用在定义或改变表(TABLE)的结构,数据类型,表之间的链接和约束等初始化工作上,他们大多在建立表时使用
DCL(Data Control Language):
是数据库控制功能。是用来设置或更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)语句。在默认状态下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人员才有权力执行DCL
二、binlog2sql安装
从mysql binlog解析出你要的sql。根据不同选项,你可以得到原始sql、回滚sql、去除主键的insert sql等。
2.1、用途
- 数据快速回滚(闪回)
- 主从切换后数据不一致的修复
- 从binlog生成标准SQL,带来的衍生功能
2.2、安装
# cd /usr/local # git clone https://github.com/danfengcao/binlog2sql.git # ls binlog2sql games java lib64 mariadb sbin src # cd binlog2sql # pip install -r requirements.txt -bash: pip: command not found -------------安装pip工具------------- # wget https://bootstrap.pypa.io/get-pip.py # python get-pip.py # pip -V #查看pip版本 pip 9.0.1 from /usr/lib/python2.7/site-packages (python 2.7) # pip install -r requirements.txt Requirement already satisfied: PyMySQL==0.7.8 in /usr/lib/python2.7/site-packages (from -r requirements.txt (line 1)) Requirement already satisfied: wheel==0.24.0 in /usr/lib/python2.7/site-packages (from -r requirements.txt (line 2)) Requirement already satisfied: mysql-replication==0.9 in /usr/lib/python2.7/site-packages (from -r requirements.txt (line 3))
2.3、user需要的最小权限集合:
select, super/replication client, replication slave权限建议授权
mysql > GRANT SELECT,REPLICATION SLAVE,REPLICATION CLIENT ON *.* to flashback@'localhost' identified by 'flashback'; mysql > GRANT SELECT,REPLICATION SLAVE,REPLICATION CLIENT ON *.* to flashback@'127.0.0.1' identified by 'flashback';
2.4、基本用法
解析出标准SQL
shell> python binlog2sql.py -h127.0.0.1 -P3306 -uadmin -p'admin' -ddatabase -t table1 table2 --start-file='mysql-bin.000002' --start-datetime='2017-01-12 18:00:00' --stop-datetime='2017-01-12 18:30:00' --start-pos=1240
解析出回滚SQL
shell> python binlog2sql.py --flashback -h127.0.0.1 -P3306 -uadmin -p'admin' -dtest -ttest3 --start-file='mysql-bin.000002' --start-position=763 --stop-position=1147
三、测试:
3.1、新建表users
create table cope_users like info_users; # 新建表 insert into cope_users select * from info_users limit 500; # 插入500行数据 delete from cope_users where id<20; # 删除20行数据
3.2、解析标准sql
# python /usr/local/binlog2sql/binlog2sql/binlog2sql.py -uflashback -pflashback -dttt -tusers --start-file='mysql-bin.000034' --start-datetime='2017-07-11 15:10:00' --stop-datetime='2017-07-11 15:12:00' DELETE FROM `ttt`.`users` WHERE `uid`='0e8e2609c748bbb052d7' AND `ip`='172.16.208.32' AND `sex`=0 AND `app_ver`='5.2.3' AND `device_type`=2 AND `guides`='' AND `last_login_time`=1481602129 AND `id`=1 AND `latitude`='' AND `add_time`=1481602080 AND `recharge_time`=0 AND `token_change_time`=1481602129 AND `expire_time`=0 AND `nickname`='阿超' AND `device_id`='cc0e154d9b5dd703eccc7d8a0dbc0f67d64b79e8' AND `push_key`='' AND `level`=0 AND `mobile`='18810895535' AND `settings`='' AND `longitude`='' AND `signature`='' AND `os_ver`='' LIMIT 1; #start 79078 end 83053 time 2017-07-11 15:11:50 DELETE FROM `ttt`.`users` WHERE `uid`='b5cfbdb4205b56703a97' AND `ip`='172.16.208.48' AND `sex`=0 AND `app_ver`='5.2.2' AND `device_type`=2 AND `guides`='' AND `last_login_time`=1481602096 AND `id`=2 AND `latitude`='' AND `add_time`=1481602096 AND `recharge_time`=0 AND `token_change_time`=1481602096 AND `expire_time`=0 AND `nickname`='家长091410' AND `device_id`='fedea666076a7906be53523acc7a8b32811354fe' AND `push_key`='7759d6772c9851a2bfc13835a3d7e7da' AND `level`=0 AND `mobile`='13629470521' AND `settings`='' AND `longitude`='' AND `signature`='' AND `os_ver`='' LIMIT 1; #start 79078 end 83053 time 2017-07-11 15:11:50
3.3、解析出回滚SQL
# python /usr/local/binlog2sql/binlog2sql/binlog2sql.py --flashback -h127.0.0.1 -P3306 -uflashback -pflashback -dttt -tusers --start-file='mysql-bin.000034' --start-position=79078 --stop-position=83053
查看解析出的sql,如无误,可打印到sql文件中/data/backup/rollback.sql
# python /usr/local/binlog2sql/binlog2sql/binlog2sql.py --flashback -uflashback -pflashback -dttt -tusers --start-file='mysql-bin.000034' --start-position=79078 --stop-position=83053> /data/backup/rollback.sql
# cat /data/backup/rollback.sql
`id`, `latitude`, `add_time`, `recharge_time`, `token_change_time`, `expire_time`, `nickname`, `device_id`, `push_key`, `level`, `mobile`, `settings`, `longitude`, `signature`, `os_ver`) VALUES ('24667530f4b16a446b3e', '172.16.218.75', 0, '5.2.93', 3, '{\"2103\":1,\"2100\":1,\"2101\":1,\"2102\":1,\"2104\":1,\"2105\":1}', 1490239125, 19, '', 1481610680, 0, 1490239125, 0, 'zf', 'da75b093-bd22-48f6-bbb1-d3296e29e9b5', 'be05183f80a96e788e0b0a99d1275392', 0, '15101538925', '', '', '', ''); #start 79078 end 83053 time 2017-07-11 15:11:50
INSERT INTO `ttt`.`users`(`uid`, `ip`, `sex`, `app_ver`, `device_type`, `guides`, `last_login_time`, `id`, `latitude`, `add_time`, `recharge_time`, `token_change_time`, `expire_time`, `nickname`, `device_id`, `push_key`, `level`, `mobile`, `settings`, `longitude`, `signature`, `os_ver`) VALUES ('77e50b4910a9389057ed', '172.16.218.37', 0, '5.2.1.14', 3, '', 1488787835, 18, '39.978212', 1481610517, 0, 1488787835, 0, '陈俊宇', 'ed0a273d-74de-4173-92c6-55d92597bc79', '', 0, '18612482272', '', '116.306826', '', ''); #start 79078 end 83053 time 2017-07-11 15:11:50
mysql连接配置
-h host; -P port; -u user; -p password
解析模式
- --realtime 持续同步binlog。可选。不加则同步至执行命令时最新的binlog位置。
- --popPk 对INSERT语句去除主键。可选。
- -B, --flashback 生成回滚语句。可选。与realtime或popPk不能同时添加。
解析范围控制
- --start-file 起始解析文件。必须。
- --start-pos start-file的起始解析位置。可选。默认为start-file的起始位置;
- --end-file 末尾解析文件。可选。默认为start-file同一个文件。若解析模式为realtime,此选项失效。
- --end-pos end-file的末尾解析位置。可选。默认为end-file的最末位置;若解析模式为realtime,此选项失效。
对象过滤
- -d, --databases 只输出目标db的sql。可选。默认为空。
- -t, --tables 只输出目标tables的sql。可选。默认为空。
3.4、开始回滚
# mysql -uroot -p000000 < /data/backup/rollback.sql
3.5、登陆数据库验证
四、注意事项
4.1、在配置文件中设置了以下参数:
server_id = 1 log_bin = /data/mysql/mysql-bin.log max_binlog_size = 1G binlog_format = row binlog_row_image = full # 默认
4.2、在闪回的时候必须启动 MySQL 服务
因为它是通过 BINLOG_DUMP 协议来获取 binlog 内容,需要读取server端 information_schema.COLUMNS 表,来获取表结构的元信息,才能拼接成 SQL 语句。因此需要给用户提供的最小权限如下:
GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'user'@'%';
源码中,主要是使用 python-mysql-replication 作为实时解析 MySQL binlog 来获取各个 EVENT。 python-mysql-replication 实现了 MySQL 复制协议,客户端伪装成 slave 来获取主的 binlog 和 EVENT。
4.3、insert、update、delete大部分时候可以解析出来标准sql和回滚sql
一种情况例外:insert、updete、delete操作之后,drop/truncate table。 此时虽然在binlog中记录了所有的event,但是使用binlog2sql生成标准sql、回滚sql的时候已经找不到了dml操作的相应的表
4.4、DDL无法使用binlog2sql闪回数据。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
# binlog2sql
# 回滚
# mysql
# mysql闪回工具binlog2sql安装配置教程详解
# mysql8.0.20配合binlog2sql的配置和简单备份恢复的步骤详解
# 可选
# 默认为
# 这篇文章
# 闪回
# 为空
# 主要是
# 主键
# 行数
# 你可以
# 你要
# 不太
# 是用来
# 找不到
# 它是
# 给大家
# 才有
# 就象
# 要多
# 用户提供
# 谢谢大家
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
网站制作壁纸教程视频,电脑壁纸网站?
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
如何快速搭建安全的FTP站点?
Laravel storage目录权限问题_Laravel文件写入权限设置
linux top下的 minerd 木马清除方法
Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程
Laravel如何实现模型的全局作用域?(Global Scope示例)
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】
php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】
JS实现鼠标移上去显示图片或微信二维码
详解jQuery中的事件
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
EditPlus中的正则表达式 实战(4)
Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
网站制作软件免费下载安装,有哪些免费下载的软件网站?
新三国志曹操传主线渭水交兵攻略
HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】
Python函数文档自动校验_规范解析【教程】
Laravel模型关联查询教程_Laravel Eloquent一对多关联写法
如何生成腾讯云建站专用兑换码?
如何在阿里云通过域名搭建网站?
如何在自有机房高效搭建专业网站?
微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】
如何在宝塔面板中修改默认建站目录?
Android Socket接口实现即时通讯实例代码
详解jQuery停止动画——stop()方法的使用
Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程
Laravel Admin后台管理框架推荐_Laravel快速开发后台工具
如何用好域名打造高点击率的自主建站?
Python高阶函数应用_函数作为参数说明【指导】
浅述节点的创建及常见功能的实现
Laravel如何从数据库删除数据_Laravel destroy和delete方法区别
如何用已有域名快速搭建网站?
百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧
如何用搬瓦工VPS快速搭建个人网站?
Laravel如何使用.env文件管理环境变量?(最佳实践)
个人摄影网站制作流程,摄影爱好者都去什么网站?
Laravel如何与Docker(Sail)协同开发?(环境搭建教程)
Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南
Laravel如何处理异常和错误?(Handler示例)
Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程
INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】
为什么要用作用域操作符_php中访问类常量与静态属性的优势【解答】
UC浏览器如何设置启动页 UC浏览器启动页设置方法
Angular 表单中正确绑定输入值以确保提交与验证正常工作
如何获取上海专业网站定制建站电话?
Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】

