MySQL [ERROR] [MY-013183]
[ERROR] [MY-013183] [InnoDB] Assertion failure,回顾记录一次因数据库(MySql 8.0)操作不当导致的生产事故顺便记录下正常重启发生的意外和解决方法(关于 [MY-013183] [InnoDB] 论坛描述,MY-013183只是断言抛出问题内存问题,应该是由于缓冲区落盘发生意外导致的,具体处理需要结合错误详细信息进行分析。如果文档中有不对的地方或有更好的方法建议,希望大家不吝赐教)
数据库重启,没启动成功
业务正常一般不会去操作数据库,除非宕机。无奈数据库安装配置存在问题需要修改配置文件使其永久生效,数据生产较快当时已经有千万的量了,么办法只有当天晚上进行数据库调整,结果数据库丝毫不给面子直接抛出一个错误[ERROR] [MY-013183] 。

好在通过错误详细分析问题可以通过数据库强制恢复,通过配置文件设置innodb_force_recover(官网描述可连接查看)从1到6成功启动(这个情况最多设置到4数据库就会恢复,如果你设置到6才启动上那就只有恭喜你了),再取消innodb_force_recover配置重启就可以收工了
数据库意外重启,抛异常连接不上
数据库意外无法正常运行(那天业务系统走得很安详,我也走得很安详),上服务器一看根目录满了,这也是没谁了反手就是一个赞(数据库安装没有使用大存储卷),麻溜清理了磁盘,释放好空间开始重启数据库(以为可以正常启动,结果当头一棒
)查看数据库服务状态是runing,高高兴兴的去连接好家伙连不上(连端口没监听)给我表里不一。
发来的数据库错误信息 [ERROR] [MY-013183] [InnoDB] Assertion failure: fil0fil.cc:10754:initial_fsize == (file->size * phy_page_size) thread 140530362709760,当我看到这个断言的时候心都凉了半截,innodb_force_recover设置1-6设置了两遍,都设置到16了(6以上都是安6处理,一般都是1-6)也没恢复回来。现在分析下错误信息应该就是落盘idb文件分页有损坏导致断言过不了,当时不行啊没有分析的时间电话都打爆了,领导都插着手站背后看得我瑟瑟发抖,只有简单整理下打算放弃当前数据库实例,通过数据库源文件进行数据库还原(别问为什么不从备份中还原,问就是还没开始做备份我就只知道这些了)通过百度大法明确了处理流程(只有逐表恢复)
- 拷贝旧库data目录,处理事故首先确保拷贝,避免反向修复无法回头也是为了保护事故现场(此处省略,后面操作都是用拷贝的这部分文件)
- 创建同版本临时数据库实例(此处省略)
- 创建与原数据库一致的数据库及表,可以从测试环境导出结构调整与生产环境一致。如果这个没有那我只有鼓掌了但是也不要慌可通过 ibd2sdi — InnoDB 表空间 SDI 提取
- ① 表名
- ② 列名和类型,列对象里面有类型对应的具体名称
- ③ 长度
4. 备份临时数据库data目录(此处省略)
- 5. 旧库ibd替换新的ibd文件,逐个修改替换表的ibd文件(如果是MyISAM引擎的表,此阶段应该就可以使用了)
- .ibd文件包含tablespace id,需要修改恢复数据.ibd文件的tablespace id和临时表建立的相同标记处为修改处需保持一致

- vi模式下,输入 :%!xxd 进行16进制编辑,使用 :%!xxd -r 转换为二进制保存或者使用winHex(编辑16进制)
- 另一种ibd解绑和绑定方法是通过命令(这个应该是之前版本的,我尝试后失败了,仅供了解)
- 解除绑定:alter table user discard tablespace;(执行完sql后,表现为表的ibd文件被删除,但是千万不要自己手动删除 )
- 绑定数据表.frm和数据.idb的关系:alter table user import tablespace;
- 注:拷贝后注意权限是正确,替换临时库ibd文件后无法正常启动可以清理或替换掉ib_logfile0、ib_logfile1,配置
innodb_force_recover=6 - 6. 备份临时库还原至正式新数据库实例中
- 备份:mysqldump -h 主机名 -P 端口 -u 用户名 -p 数据库名 > 备份文件.sql
- 还原:mysql> source 备份文件.sql
- 注:备份文件.sql会清理一次表然后再创建写入数据库
- 以上6步操作数据逐步恢复,本以为万事大吉,可天有不测风云。ibd分页坏了,当读取到坏页位置时该出问题的时候还是得出问题,读取到损坏页时数据库会宕掉重启日志会输出多少页读取异常(当时忙着解决问题没存错误信息),只有找了个ibd操作工具Inno_space清理掉损坏页那一页的数据就丢了(有几页坏了丢了两三百条数据),好在损坏页数据可以不用完全恢复。
最后
- 虽然数据大部分恢复了,但是页坏了的那部分数据没恢复,如果这部份数据是比较重要,损失就相当严重了。
- 希望大家服务器一定要做好相关监控(cpu、内存、网络、磁盘等)、数据库按照相关备份方案做好备份
- 也希望大家永远也不需要参考这篇文章,都是教训呀。
- 欢迎大家留言讨论
参考引用
- 关于 [MY-013183] [InnoDB] CD Tavares 论坛描述:https://forums.mysql.com/read.php?22,672274,672274
- 官网强制恢复InnoDB:https://dev.mysql.com/doc/refman/8.0/en/forcing-innodb-recovery.html
- 官网ibd2sdi — InnoDB 表空间 SDI 提取实用程序:https://dev.mysql.com/doc/refman/8.0/en/ibd2sdi.html
- HuaLingPiaoXue MYSQL8.0 根据IBD文件查看表结构:https://blog.csdn.net/HuaLingPiaoXue/article/details/104953594
- 巴老板 mysql frm ibd 恢复工具_MySQL innodb引擎下根据.frm和.ibd文件恢复表结构和数据:https://blog.csdn.net/weixin_36275231/article/details/113253297
- Inno_space工具:https://github.com/baotiao/inno_space
MySQL [ERROR] [MY-013183]的更多相关文章
- 关于mysql登录异常处理方法 - mysql ERROR 1045 (28000)
今天在开发过程中遇到了一个很令人头痛的问题?? 使用 百度经验的步骤 [http://jingyan.baidu.com/article/495ba841ef412d38b30edeb2.html]修 ...
- MySQL ERROR 1005: Can't create table (errno: 150)的错误解决办法
在mysql 中建立引用约束的时候会出现MySQL ERROR 1005: Can't create table (errno: 150)的错误信息结果是不能建立 引用约束. 出现问题的大致情况 1. ...
- 彻底解决phpcms v9升级后,文章发布出现: Mysql 1267错误:MySQL Error : Illegal mix of collations 解决办法
彻底解决phpcms v9升级后,文章发布出现: MySQL Query : SELECT * FROM `withli_a`.`v9_keyword` WHERE `keyword` = '吼吼' ...
- mysql: error while loading shared libraries: libmysqlclient.so.16
[root@host_41 mysql]# mysqlmysql: error while loading shared libraries: libmysqlclient.so.16: cannot ...
- MySQL Error Handling in Stored Procedures 2
Summary: this tutorial shows you how to use MySQL handler to handle exceptions or errors encountered ...
- MySQL Error Handling in Stored Procedures
http://www.mysqltutorial.org/mysql-error-handling-in-stored-procedures/ mysql存储过程中的异常处理 定义异常捕获类型及处 ...
- [转]MySQL: Starting MySQL….. ERROR! The server quit without updating PID file
转自: http://icesquare.com/wordpress/mysql-starting-mysql-error-the-server-quit-without-updating-pid-f ...
- mysql ERROR 1045 (28000): Access denied for user解决方法
一 这种情况下是 root@% update mysql.user set host='%' where user='root' and host='localhost'; flush privile ...
- MySQL: Starting MySQL….. ERROR! The server quit without updating PID file解决办法
MySQL: Starting MySQL….. ERROR! The server quit without updating PID file解决办法 1 问题 [root@localhost m ...
- centos6.6下编译安装mysql5.6之后启动失败:Starting MySQL... ERROR! The server quit without updating PID file (/var/lib/mysql/localhost.localdomain.pid).
今天在编译安装mysql5.6时候出现Starting MySQL... ERROR! The server quit without updating PID file (/var/lib/mysq ...
随机推荐
- 计算机网络再次整理————tcp例子第二前奏[四]
前言 前文我们介绍了网络协议的各层,同时也介绍了一下我们在编写代码时候的服务端的accept.bind.listen.connect.send做了什么. 可以说是从宏观的角度,或者代码开发的角度来说的 ...
- Codeforces Round #739 (Div. 3)
A. Dislike of Threes 简单的水题,预处理即可 AC_CODE #include <bits/stdc++.h> using namespace std; templat ...
- ApacheCN PHP 译文集 20211101 更新
PHP 入门指南 零.序言 一.PHP 入门 二.数组和循环 三.函数和类 四.数据操作 五.构建 PHP Web 应用 六.搭建 PHP 框架 七.认证与用户管理 八.建立联系人管理系统 使用 PH ...
- ABC209 E Shiritori
考虑对这个问题进行转化: 显然我们只关注每个串前三个棋子和后三个棋子,并且根据题目的特性,我们可以将任意的三个字符看作点,将一个字符串看作连接两个点的边,这样我们得到了一张点数为 \(52 ^ 3\) ...
- [HNOI2009]双递增序列
不难发现本题贪心是不好做的,可以考虑 \(dp\). 首先的一个想法就是令 \(dp_{i, j, k, l}\) 表示当前选到第 \(i\) 个位置,当前第一个序列选了 \(j\) 个数,当前第一个 ...
- spring学习四:Spring中的后置处理器BeanPostProcessor
BeanPostProcessor接口作用: 如果我们想在Spring容器中完成bean实例化.配置以及其他初始化方法前后要添加一些自己逻辑处理.我们需要定义一个或多个BeanPostProcesso ...
- Java Thread.currentThread()和This的区别
感谢原文作者:王婷婷-Smily 原文链接:https://blog.csdn.net/dfshsdr/article/details/92760135 缘由 很多人认为多线程中的Thread.cur ...
- Android图表库hellocharts详解
感谢大佬:https://www.cnblogs.com/huolongluo/p/5988644.html 因为项目需要搞一个折线图,按照日期显示相应的成绩,所以有了本文. 以前用过一次XCL-ch ...
- transition过渡2D、3D效果
过渡(transition)是CSS3中具有颠覆性的特征之一,我们可以在不使用 Flash 动画或 JavaScript 的情况下,当元素从一种样式变换为另一种样式时为元素添加效果. 帧动画:通过一帧 ...
- 简单实现UITableView索引功能(中英文首字母索引)(一) ByH罗
UITableView索引功能是常见的,主要是获取中英文的首字母并排序,系统自带获取首字母 //系统获取首字母 - (NSString *) pinyinFirstLetter:(NSString*) ...