首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL中使用undrop来恢复drop(上)

而如果是DDL,比如DROP,那就得叹声气了。...GitHub上有一个很不错的项目是undrop,基于InnoDB,也就意味着如果你所在的环境有了drop操作还是存在恢复的可能了,当然这个过程需要谨慎,建议大家在测试环境先练习测试论证后再做决定,当然我们希望这个工具永远不要排上用场...不过实际上我们可以做个减法,只创建一个我们需要重点关注的,然后导入数据即可。...整个初始化的工作,我们以actor为例,手工摘取出actor的建表语句,然后运行sakila-data.sql脚本即可。...REDUNDANT),D(D 表示只恢复被删除的记录),f生成文件 然后依次使用c_parser来解析页得到其他几个数据字典的信息,比如(SYS_INDEXES,SYS_COLUMNS,SYS_FIELDS

2.2K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    xfs文件系统浅析 -- 恢复drop

    导读我们知道ibd2sql可以解析ibd文件从而恢复mysql的数据, 但没得ibd文件的时候又该怎么办呢? (哎呀, 不小心drop, 又没得备份!)...这时候就需要先从文件系统恢复数据文件了. mysql通常运行在linux服务器上, 通常是使用的xfs文件系统, 市面上也有不少该类工具, 有收费的, 也有免费的(比如testdisk,支持多种OS/FS...mysql数据文件)第二个参数: 要恢复的文件的inode (就是上面扫描出来的文件)第三个参数: 恢复的文件存放的文件名字....system chmod 640 /data/mysql_3306/mysqldata/db2/testdrop_20241015.ibd -- 导入空间alter table `db2`....`testdrop_20241015` limit 1;看来我们成功恢复drop总结虽然我们已经验证了可以从文件系统恢复drop, 但还是要做好备份.我们目前只支持简单的情况,比如只支持v5,

    22840

    MySQL如何快速恢复(物理方式)

    的cfg文件和ibd文件到目标test2,并修改文件权限: cp test1.cfg test2.cfg cp test1.ibd test2.ibd chown -R mysql.mysql test2...locked with LOCK TABLES 7、执行unlock tables,释放源的test1.cfg文件,然后导入ibd文件: mysql> unlock tables; Query OK..., 0 rows affected (0.00 sec) 并用alter table的方法为目标test2导入这个ibd文件: mysql> alter table test2 import tablespace...show create view BUG解析 MySQL分区对NULL值的处理 实现一个简单的Database8(译文) 用 LSN 画个 PAGE MAP ---- 关于 GreatSQL...GreatSQL是由万里数据库维护的MySQL分支,专注于提升MGR可靠性及性能,支持InnoDB并行查询特性,是适用于金融级应用的MySQL分支版本。

    1.6K80

    MySQL删除数据、清空命令(truncate、drop、delete 区别)

    一、MySQL清空数据三种方法1.1 清空数据:truncatesql命令#清空多张、库中所有的数据truncate table table_name1,table_name2,......、多行、乃至整张每次删除一行,都在事务日志中为所删除的每行记录一项,可回滚如果不加where条件,表示删除中所有数据,仅删除数据、保留结构,同时也不释放空间MySQL、Mariadb、PostgreSQL...三、truncate、drop、delete区别truncate、delete和drop都是用于删除数据或的操作,但它们之间有一些关键的区别:操作类型:truncate:删除中的所有数据,保留结构...drop:执行速度较快,因为它一次性删除整个。回滚能力:truncate:不可回滚,一旦执行,数据将被永久删除、无法恢复。delete:可以回滚,使用ROLLBACK语句可以撤销删除操作。...drop:不可回滚,一旦执行,结构和数据都将被永久删除。触发器:truncate:不会触发触发器。delete:会触发触发器。drop:不会触发触发器,因为它是删除整个

    23.8K14

    通过全备+主从同步恢复drop的库或

    MySQLdrop 等高危误操作后恢复方法 实验目的: 本次实验以恢复drop操作为例,使用不同方法进行误操作的数据恢复....方法: 利用master同步(本文)] 伪master+Binlog+同步 利用binlog改为realy-log在临时slave更新 没有备份怎么恢复drop(利用undrop-for-innodb...) 压力:在做本次实验过程用,使用sysbench同时做读写模拟压力(28thread+10*100000行) 2.本实验的前置条件: 在drop前至少有一次全量备份 从全备到drop操作时间点有全程binlog...:DROP TABLE `t2`: 在mysql-bin.000020中找到对应位置: # at 97871478 #180731 19:33:29 server id 1853506 end_log_pos...count(*) | +----------+ | 163818 | +----------+ 1 row in set (0.10 sec) root@localhost [(none)]> 将数据导出

    45820

    MySQL恢复步骤详解

    万幸的是,只是单写花了,而不是哪位大神在DB里面玩drop table。...虽然已经很久没进行单恢复了,但大致步骤都还在脑海中,没花多久就搞定了~ 言归正传,记录一下单恢复的步骤和关键点,提醒自己也提醒大家。...第四步: 在主库上将写花的改名,其目的有二个,其一,停止对这个的写入(当然这对业务会有一定的影响,会出现一段时间内的写入失败报警,需要提前和业务部门联系好),其二,一旦恢复失败,至少还有一个写花的存在...第五步: 基本DBA的事情就没有了,这时候就需要告诉开发同学恢复完毕,进行应用测试及数据正确性效验了。如果一切都没有问题之后,我们需要将刚才rename的drop掉,整个恢复操作就算大功告成了。...drop table if exists tablename_bak; 数据库恢复是每个DBA必备的技能,需要熟练掌握,希望读过这篇文章的同学们都可以轻车熟路的进行恢复操作。

    2.2K10

    优雅的dropmysql库中1TB大

    要是问大家,知道怎么从mysql数据库中drop掉业务,很多人肯定会说,so easy,用drop table t_test语句不就完事了,这是初生牛犊不怕虎,你要是如此简单,去线上业务库中drop掉一张...1TB大小的,造成长时间的业务无法访问数据库,更严重,导致数据库崩溃,宕机都是可能的。...下面就先聊聊,drop table语句背后的事情,语句执行之后,主要做2两件事情 1、清除Buffer Pool缓冲 在drop table时,innodb引擎会清理该在每个buffer pool实例中中对应的数据块页面...t_test.ibd.bak 删除drop table t_test; 最后就是要真正删除掉物理文件,释放文件所占用的磁盘空间,那么问题来了,如果优雅的删除物理文件呢,在这里推荐大家coreutils.../t_test.ibd.hdlk done rm -rf /data/mysql/t_test.ibd.hdlk ; 最后,给大家一个建议,不要在业务高峰期做drop table操作,一定要在业务低峰期做

    2.4K20
    领券