navicat误删数据恢复_sqlserver2008还原数据库

navicat误删数据恢复_sqlserver2008还原数据库以前mysql回复误删数据用的比较多的是基于原始binlog或binlog2sql,昨天又遇到一例开发误删的问题,这次用用美团开源的工具 MyFlash试试。用下来效果还是不错的,基于库 or 表的…

以前mysql回复误删数据用的比较多的是基于原始binlog或binlog2sql,昨天又遇到一例开发误删的问题,这次用用美团开源的工具 MyFlash试试。用下来效果还是不错的,基于库 or 表的过滤可以有效的筛选出来目标sql。

#### 项目地址

https://github.com/Meituan-Dianping/MyFlash/

 

####实现原理

https://mp.weixin.qq.com/s?__biz=MjM5NjQ5MTI5OA==&mid=2651747096&idx=1&sn=e561ce9254f69c3fcd04c73b44e56e69&chksm=bd12aa558a65234332298e1d611da408ec45afb2d08ecd22078a600379525e75b2fa13149fb0&mpshare=1&scene=23&srcid=1116o1gBWoNf47Rv1E1ngYir#rd

代码100分

####限制

         1. binlog格式必须为row,且binlog_row_image=full

         2. 仅支持5.6与5.7

         3. 只能回滚DML(增、删、改)

 

####安装

         cd /opt

         git clone https://github.com/Meituan-Dianping/MyFlash.git

         yum install libgnomeui-devel -y

         cd /opt/flashback/MyFlash/binary

         gcc -w  `pkg-config –cflags –libs glib-2.0` source/binlogParseGlib.c  -o binary/flashback

 

####参数介绍

         下面的这些参数是可以任意组合的。

         1.databaseNames

         指定需要回滚的数据库名。多个数据库可以用“,”隔开。如果不指定该参数,相当于指定了所有数据库。

         2.tableNames

         指定需要回滚的表名。多个表可以用“,”隔开。如果不指定该参数,相当于指定了所有表。

         3.start-position

         指定回滚开始的位置。如不指定,从文件的开始处回滚。请指定正确的有效的位置,否则无法回滚

         4.stop-position

         指定回滚结束的位置。如不指定,回滚到文件结尾。请指定正确的有效的位置,否则无法回滚

         5.start-datetime

         指定回滚的开始时间。注意格式必须是 %Y-%m-%d %H:%M:%S。 如不指定,则不限定时间

         6.stop-datetime

         指定回滚的结束时间。注意格式必须是 %Y-%m-%d %H:%M:%S。 如不指定,则不限定时间

         7.sqlTypes

         指定需要回滚的sql类型。目前支持的过滤类型是INSERT, UPDATE ,DELETE。多个类型可以用“,”隔开。

         8.maxSplitSize

         一旦指定该参数,对文件进行固定尺寸的分割(单位为M),过滤条件有效,但不进行回滚操作。该参数主要用来将大的binlog文件切割,防止单次应用的binlog尺寸过大,对线上造成压力

         9.binlogFileNames

         指定需要回滚的binlog文件,目前只支持单个文件,后续会增加多个文件支持

         10.outBinlogFileNameBase

         指定输出的binlog文件前缀,如不指定,则默认为binlog_output_base.flashback

         11.logLevel

         仅供开发者使用,默认级别为error级别。在生产环境中不要修改这个级别,否则输出过多

         12.include-gtids

         指定需要回滚的gtid,支持gtid的单个和范围两种形式。

         13.exclude-gtids

         指定不需要回滚的gtid,用法同include-gtids

 

#### 回滚(普通文件)

         1.打捞

         测试发现不指定 –stop-position=601671361 效果相同

代码100分         ./flashback --binlogFileNames=/data0/mysql/3308_mofang/mysql-bin.000608 --start-position=600264778   --sqlTypes="DELETE" --databaseNames=report_forms --tableNames=t_sys_report_cache --outBinlogFileNameBase=mysql-bin.000608.flash  

          

         2.查看数据

         mysqlbinlog --base64-output="decode-rows" mysql-bin.000608.flash.flashback  -vvv 

 

         3.恢复

代码100分         mysqlbinlog mysql-bin.000608.flash.flashback |mysql -uroot -p"123" -S /tmp/mysql_5555.sock

        

####回滚(大文件)

         回滚

         ./flashback –binlogFileNames=haha.000042

         切割大文件

         ./flashback –maxSplitSize=1 –binlogFileNames=binlog_output_base.flashback

         应用

         mysqlbinlog binlog_output_base.flashback.000001 | mysql -h<host> -u<user> -p

         …

         mysqlbinlog binlog_output_base.flashback.<N> | mysql -h<host> -u<user> -p

 

        

        

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10748.html

(0)
上一篇 2022-12-22
下一篇 2022-12-22

相关推荐

  • 事务隔离(3)「终于解决」

    事务隔离(3)「终于解决」事务 保证一组数据库操作,要么全部成功,要么全部失败。 特性 原子性: 一致性: 隔离性: 持久性: 当数据库中有多个事务同时执行的时候,就可能出现脏读( )、不可重复读( )、幻读( )的问题,为了

    2023-02-11
    150
  • 查看Python包版本的方法

    查看Python包版本的方法Python作为一种通用型编程语言,在不同的领域都有广泛的使用。开发过程中需要使用各种第三方包,因此查看包的版本是必不可少的。

    2024-06-07
    63
  • 优美精准的numpy切片操作技巧

    优美精准的numpy切片操作技巧从事数据科学和机器学习的人都知道,numpy是必备的工具之一。在numpy中,切片(slicing)是经常用到的操作之一。简单的切片是很容易掌握的,但是当涉及到多维数组,或者需要高效地选择元素时,我们就需要更加高效和优美的numpy切片技巧。

    2024-04-17
    107
  • 中台架构与实现:基于DDD和微服务_tidb架构

    中台架构与实现:基于DDD和微服务_tidb架构数据库作为信息系统的核心,数据库设计需要根据用户的需求,针对业务逻辑上,设计结构和建立数据库。由于数据库应用系统的复杂性,数据库的设计不可能一蹴而就,也没有统一的最好的设计结构,因为对于不同的业务来…

    2023-04-11
    150
  • 使用Mongo命令行

    使用Mongo命令行伴随着大数据技术的快速发展和全球数据规模的爆炸式增长,我们已经走到了一个数据万物互联、数据驱动一切的时代。在这样一个大数据时代,各种数据库管理系统的应用场景越来越广泛,MongoDB正是其中的重要一员。MongoDB是一个开源、面向文档的NoSQL数据库,使用简单、可靠、灵活、可扩展,且擅长以高效的方式存储大量数据。该数据库市场分额占有率逐年递增,很多互联网公司选择MongoDB作为自己的首选数据库。

    2024-06-20
    50
  • MongoDB高可用集群搭建

    MongoDB高可用集群搭建MongoDB高可用集群搭建 MongoDB副本集搭建 准备三台服务器:   10.175.120.131(主节点)   10.175.121.134(副本节点)   10.175.121.136(…

    2023-03-26
    156
  • postgres timesaledb MySQL数据库容器化部署[通俗易懂]

    postgres timesaledb MySQL数据库容器化部署[通俗易懂](base) [root@dadevenv ~]# curl -fsSL https://get.docker.com | bash -s docker –mirror Aliyun# Execu…

    2023-04-05
    157
  • mysql 常用语句_mysql字符串常用函数

    mysql 常用语句_mysql字符串常用函数连接字符串 select CONCAT(“1″,”,”,”2″);

    2023-03-13
    144

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注