博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
利用 innodb_force_recovery 解决MySQL服务器crash无法重启问题
阅读量:6967 次
发布时间:2019-06-27

本文共 3666 字,大约阅读时间需要 12 分钟。

背景

      MySQL服务器因为磁盘阵列损坏机器crash,重启MySQL服务时 报如下错误:

InnoDB: Reading tablespace information from the .ibd files...InnoDB: Restoring possible half-written data pages from the doublewriteInnoDB: buffer...InnoDB: Doing recovery: scanned up to log sequence number 9120034833150125 16:12:51 InnoDB: Starting an apply batch of log records to the database...InnoDB: Progress in percents: 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 150125 16:12:51 [ERROR] mysqld got signal 11 ;This could be because you hit a bug. It is also possible that this binaryor one of the libraries it was linked against is corrupt, improperly built,or misconfigured. This error can also be caused by malfunctioning hardware.To report this bug, see http://kb.askmonty.org/en/reporting-bugsWe will try our best to scrape up some info that will hopefully helpdiagnose the problem, but since we have already crashed, something is definitely wrong and this may fail.Server version: 5.5.37-MariaDB-logkey_buffer_size=268435456read_buffer_size=1048576max_used_connections=0max_threads=1002thread_count=0It is possible that mysqld could use up to key_buffer_size + (read_buffer_size + sort_buffer_size)*max_threads = 2332093 K bytes of memory41 Hope that.

 

 分析

       主要关注 mysqld got signal 11 的问题,从日志内容分析来看,数据库在机器crash 导致日志文件损坏,重启之后无法正常恢复,更无法正常对外提供服务。

解决

       因为日志已经损坏,这里采用非常规手段,首先修改innodb_force_recovery参数,使mysqld跳过恢复步骤,将mysqld 启动,将数据导出来然后重建数据库。
innodb_force_recovery可以设置为1-6,大的数字包含前面所有数字的影响。

1. (SRV_FORCE_IGNORE_CORRUPT):忽略检查到的corrupt页。

2. (SRV_FORCE_NO_BACKGROUND):阻止主线程的运行,如主线程需要执行full purge操作,会导致crash。
3. (SRV_FORCE_NO_TRX_UNDO):不执行事务回滚操作。
4. (SRV_FORCE_NO_IBUF_MERGE):不执行插入缓冲的合并操作。
5. (SRV_FORCE_NO_UNDO_LOG_SCAN):不查看重做日志,InnoDB存储引擎会将未提交的事务视为已提交。
6. (SRV_FORCE_NO_LOG_REDO):不执行前滚的操作。

注意

a 当设置参数值大于0后,可以对表进行select,create,drop操作,但insert,update或者delete这类操作是不允许的。
b 当innodb_purge_threads 和 innodb_force_recovery一起设置会出现一种loop现象:

150125 17:07:42 InnoDB: Waiting for the background threads to start150125 17:07:43 InnoDB: Waiting for the background threads to start150125 17:07:44 InnoDB: Waiting for the background threads to start150125 17:07:45 InnoDB: Waiting for the background threads to start150125 17:07:46 InnoDB: Waiting for the background threads to start150125 17:07:47 InnoDB: Waiting for the background threads to start

在my.cnf中修改以下两个参数

innodb_force_recovery=6

innodb_purge_thread=0

重启MySQL

150125 17:10:47 [Note] Crash recovery finished.150125 17:10:47 [Note] Server socket created on IP: '0.0.0.0'.150125 17:10:47 [Note] Event Scheduler: Loaded 0 events150125 17:10:47 [Note] /vdata/webserver/mysql/bin/mysqld: ready for connections.Version: '5.5.37-MariaDB-log' socket: '/tmp/mysql.sock' port: 3306 Source distribution

立即对数据库做逻辑导出 ,完成之后将innodb_force_recovery设置为0 ,innodb_purge_thread=1 ,然后重建数据库 。

另外 MySQL 版本 5.5以及之前 ,当innodb_purge_threads =1,innodb_force_recovery >1 的情况会出现上文提到的循环报warning 问题(=1 没有问题),

原因:
MySQL 的源代码中显示 当innodb_purge_threads 和 innodb_force_recovery一起设置会出现loop循环

while (srv_shutdown_state == SRV_SHUTDOWN_NONE) { if (srv_thread_has_reserved_slot(SRV_MASTER) == ULINT_UNDEFINED || (srv_n_purge_threads == 1 && srv_thread_has_reserved_slot(SRV_WORKER) == ULINT_UNDEFINED)) { ut_print_timestamp(stderr); fprintf(stderr, " InnoDB: Waiting for the background threads to start\n");os_thread_sleep(1000000); } else { break; } }

所以当需要设置innodb_force_recovery>1的时候需要关闭 innodb_purge_threads,设置为0(默认)。

四 小结

       MySQL crash 或者 MySQL 数据库服务器 crash 会导致各种各样的问题 ,比如主备之间的error 1594 (5.6 版本开启crash-safe ,会最大程度上避免 error 1594的问题,以后会写5.6新特性介绍该功能 ),error 1236, 日志损坏,数据文件损坏 ,等等,本案例只是其中的一种,细心从日志中找的相关错误提示,逐步解决即可。

转载于:https://www.cnblogs.com/vadim/p/7380654.html

你可能感兴趣的文章
MySQL-To-JSON 的 Kafka 生产者
查看>>
[网络篇]ESP8266-SDK教程(五)之SmartConfig、Airkiss等多种配网方式
查看>>
C4C销售订单中业务伙伴的自动决定功能Partner determination procedure
查看>>
关于Java序列化你不知道的事
查看>>
使用 HTML5,通过创建 cache manifest 文件,可以轻松地创建 web 应用的离线版本。...
查看>>
项目管理助力组织赢在VUCA时代
查看>>
ybg_auth 4.2 版本发布,基于微服务开发业务框架
查看>>
浏览器事件机制中事件触发三个阶段?
查看>>
Python数据分析之糗事百科第二弹
查看>>
[剑指offer] 二叉搜索树与双向链表
查看>>
Java集合框架源码解析之LinkedHashMap
查看>>
读《学习之道》— 放松点,有时候太勤奋也是一种病
查看>>
王者荣耀使用什么编程语言开发的?
查看>>
Kubernetes-离线部署Kubernetes 1.9.0
查看>>
实验吧---忘记密码了
查看>>
C/C++中int128的那点事
查看>>
JAVA中Sql时间格式与util时间格式转换
查看>>
前端概述及网页入门
查看>>
Java Servlet web.xml 配置详解
查看>>
javascript mvc 代码
查看>>