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

存储崩溃MySQL数据库恢复案例

RAID5磁盘阵列,由于未知的原因导致存储忽然崩溃无法启动,RAID5阵列中的虚拟机全部丢失,其中3台虚拟机为重要数据,需要主要针对该3台虚拟机进行数据恢复。...经客户描述故障过程为:第一块硬盘掉线后系统启动热备盘进行替换,第二块硬盘掉线时RAID5处于降级状态,第三块硬盘掉线导致RAID阵列崩溃。下面看看北亚工程师是如何进行操作的吧!...四、通过分析数据库页提取数据 本次数据恢复的虚拟机内有mysql数据库,可以利用数据库底层存储的特殊性进行数据页扫描,提取数据。...五、获取mysql数据页并分析 根据mysql数据页特征进行数据页扫描并导出(innodb引擎可以使用此方案,myisam因为没有“数据页”概念所以不可用),分析系统表获取各用户表信息,根据各个表的id...分别使用两组不同表结构对数据记录进行提取并导入恢复环境中的mysql数据库内,然后剔除各个表中因为表结构变更造成的乱码数据,最后将两组数据分别导出为.sql文件。

4.6K20
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL 崩溃恢复过程分析

天有不测风云,数据库有旦夕祸福。 前面写 Redo 日志的文章介绍过,数据库正常运行时,Redo 日志就是个累赘。 现在,终于到了 Redo 日志扬眉吐气,大显身手的时候了。...崩溃直接就是戛然而止,撂挑子不干了,还没来得及进行的那些收尾工作怎么办? 那就只能等待下次启动的时候再干了,这就是本文要介绍的崩溃恢复过程。 2....就突然崩溃了,截断表空间操作还没有完成,那怎么办?...undo slot 关联了 undo 段,说明数据库崩溃时,undo 段中的事务还没有完成,事务状态可能是以下 3 种之一: TRX_STATE_ACTIVE,表示事务还没有进入提交阶段。...总结 MySQL 崩溃恢复过程的核心工作有 2 点: 对于 MySQL 崩溃之前还没有刷新到磁盘的数据页(也就是脏页),用 Redo 日志把这些数据页恢复到 MySQL 崩溃之前那一刻的状态,这相当于对脏页进行一次刷盘操作

94410

MySQL误删怎么办

如果临时库上有多个数据库,可以在使用mysqlbinlog时,加上一个-database参数,用来指定误删表所在的库,这样就避免了在恢复数据时还要应用其他库日志的情况(读取无用日志) 跳过误操作的binlog...恢复数据慢怎么解决 主要原因: ● 如果是误删表,最好就是只恢复出这张表,但是mysqlbinlog工具并不能指定只解析一个表的日志 ● 用mysqlbinlog解析出日志应用,应用日志的过程只能是单线程,MySQL...就可以让临时库只同步误操作的表 也可以用上并行复制来加速整个数据恢复过程 如果备库上已经删除了临时实例需要的binlog怎么办?...确保业务无影响以后再删 ○ 改名的时候,要求给表名加固定的后缀(比如_to_be_deleted),然后删除表的动作必须通过管理系统执行,并且管理系删除表的时候,之恩给你删除固定后缀的表 使用rm命令误删整个MySQL...实例 对于一个有高可用机制的MySQL集群来说,rm删除数据后,只要不是恶意的把整个集群删除,而只是删除了其中一个节点的数据的话,HA就会开始工作,选出一个新的主库,从而保证整个集群的正常工作。

1.5K40

MySQL 死锁了,怎么办

之前分享过 MySQL 死锁的文章,然后很多读者对「插入意向锁」认识很迷糊。 大家误以为「插入意向锁」是意向锁,也就是表锁,确实这个名字很让人误解。...# 事务 A mysql> begin; Query OK, 0 rows affected (0.01 sec) mysql> select * from t_order where order_no...下面举个唯一二级索引冲突的例子,MySQL 8.0 版本,事务隔离级别为可重复读(默认隔离级别)。...在数据库层面,有两种策略通过「打破循环等待条件」来解除死锁状态: 设置事务等待锁的超时时间。当一个事务的等待时间超过该值后,就对这个事务进行回滚,于是锁就释放了,另一个事务就可以继续执行了。...---- 参考资料: 《MySQL 是怎样运行的?》 http://mysql.taobao.org/monthly/2020/09/06/ ---- 最后说个段子: 面试官: 解释下什么是死锁?

1.4K20

mysql 1075错误怎么办

当我们使用mysql数据库的时候,非常容易遇上mysql1075的报错。 在mysql中1075报错的原因是一个字段设置了自动递增,另外一个字段被设置为主键,发生冲突。...在数据库当中,勾选自动递增的,系统会默认为主键,所以必须设置自增的一列为主键才可以。  看到这里,很多同学可能有所疑惑,树懒君来为你科普以下什么是主键和主键的自动递增字段 每个表都应有一个主键字段。...如果我们开始建表的时候没有设置任何字段为主键,那么,现在我们要添加一个主键或者说是要让一个字段变为自动编号,哪么该怎么办呢?...column id int unsigned not null auto_increment, >>add primary key(id); 就这样,不但设置了自动编号,同时设置了主键,就不会遇到mysql

1.4K00

--MYSQL MGR 崩溃后的修复和问题查找

MYSQL 的 GROUP REPLICATION 估计大多数的公司都没有用,即使用也不是在主要的项目和关键的地方。...所以网上相关MYSQL Group Replicaiton 的的修复的东西也不多。赶巧,最近我们的测试系统的 MGR 崩溃了。...我们的MGR 的测试系统是三台MYSQL 5.7.23 + Proxysql 组成的,曾经坏过一台机器(网络原因),但MGR 稳稳的提供数据库服务,这次的崩溃和上次比,没有那么简单。三台机器挂了两台。...在保存了错误日志后,我尝试恢复,主库,重启启动后可以登录,并且再次重新运行命令,一般你要重新来过,最好要知道,崩溃中的那个库时最后的主库,然后在那个主库上操作下面的命令。...后面因为2号机的数据库还是正常的,所以直接resetart 1号MYSQL,下面的图也就是后边备份1号机在备份的时候,和XTRABACKUP PERPARE 的时候异常慢的一个原因。

2.6K50

最好用的Mysql数据库客户端Sequel Pro使用及崩溃解决方案

今天给大家推荐一款我用了多年,感觉非常好用的Mysql客户端——Sequel Pro,开源客户端,目前只有Mac版本。...推荐这款软件的原因很简单,就是最近用它连接Mysql 8时直接崩溃,通过各种途径终于找到解决方案了。没有了崩溃的bug,才更值得推荐。 下面就来简单了解一下这款软件的功能吧。.../wp-content/uploads/2020/03/sequel-2.jpg)] ①位置可以选择数据库,点击进去可以创建数据库。...在Mac系统下会出现关闭崩溃、连接Mysql 8 崩溃等问题。 那么,如何解决呢?花了一上午的时间终于找到解决方案了。...原文链接:《最好用的Mysql数据库客户端Sequel Pro使用及崩溃解决方案》

5.1K30

第09问:MySQL 莫名崩溃,如何保留现场?

问题 我的 MySQL 偶尔崩溃,如果需要追查原因,应该如何保留现场? 实验 MySQL 随着版本不停迭代,崩溃的现象越来越少,也越来越隐蔽。...一旦遇到生产环境上的 MySQL 崩溃,就需要保留现场信息,供分析用。虽然 MySQL 的 error log 中会打印部分信息,但对于比较隐蔽的崩溃,往往显得力不从心。...我们先安装一个 5.7 的数据库, 将其停掉,按照 bug #95294 的描述变更配置, 手工启动 mysqld,可以看到 mysqld 无声无息的退出了, 检查 error log,可以看到 MySQL...是因为异常崩溃了, error log 中有一段堆栈信息,可以用来判断这个崩溃的问题, 以上是 MySQL 能提供的所有信息,无法针对一些复杂场景进行分析。...结论 通过开启操作系统级别、放开用户限制、启用 MySQL 参数三个步骤,我们启用了 MySQL 的 coredump 功能,使得 MySQL 崩溃时留下了足够的线索。

78120

糟了,生产环境MySQL主从数据库不一致怎么办?!

问题 今天发现Mysql的主从数据库没有同步 先上Master库: mysql>show processlist; 查看下进程是否Sleep太多。发现很正常。...mysql> show master status; +-------------------+----------+--------------+---------------------------...mysql.bak.sql 这里注意一点:数据库备份一定要定期进行,可以用shell脚本或者python脚本,都比较方便,确保数据万无一失。...备份文件传到从库机器,进行数据恢复 scp mysql.bak.sql root@192.168.128.101:/tmp/ 5.停止从库的状态 mysql> stop slave; 6.然后到从库执行...mysql命令,导入数据备份 mysql> source /tmp/mysql.bak.sql 7.设置从库同步,注意该处的同步点,就是主库show master status信息里的| File|

1.2K31

MySQL 忘记密码,该怎么办

本文主要介绍,mysql5.7版本的数据库,忘记密码的解决方案!...一、问题背景 很久之前,小编在linux(centos7)服务器上安装了mysql5.7的数据库,但是很长时间没有使用过,也不知道里面是否有有用的数据库,密码也忘记了。...u root -p #如果出现输入密码,直接回车,就可以进入数据库了 2.2、修改root密码 #登录mysql,此时还没有进入数据库,使用如下命令 use mysql; #修改root密码(mysql5.7...; #退出 exit; 2.3、新增管理员用户 如果你不想修改root密码,可以新增一个管理员用户,操作如下: #登录mysql,此时还没有进入数据库,使用如下命令 use mysql; #刷新数据库...,进入数据库之后,修改密码 ALTER USER 'root'@'localhost' IDENTIFIED BY 'Hello@123456'; #因为mysql8,使用强校验,所以,如果密码过于简单

3.1K10
领券