问题

我的 MySQL 偶尔崩溃,如果需要追查原因,应该如何保留现场?

实验

MySQL 随着版本不停迭代,崩溃的现象越来越少,也越来越隐蔽。

一旦遇到生产环境上的 MySQL 崩溃,就需要保留现场信息,供分析用。虽然 MySQL 的 error log 中会打印部分信息,但对于比较隐蔽的崩溃,往往显得力不从心。

因此我推荐开启 coredump,以备 MySQL 诊断需要。

我们来模拟一个崩溃场景,然后配置 coredump 看看效果。

选取一个容易复现崩溃的 bug,我们选择了 bug #95294。

我们先安装一个 5.7 的数据库,

将其停掉,按照 bug #95294 的描述变更配置,

手工启动 mysqld,可以看到 mysqld 无声无息的退出了,

检查 error log,可以看到 MySQL 是因为异常崩溃了,

error log 中有一段堆栈信息,可以用来判断这个崩溃的问题,

以上是 MySQL 能提供的所有信息,无法针对一些复杂场景进行分析。

下面我们开启 coredump,让 MySQL 在崩溃时能提供更多信息:

以下命令开启了系统级别一些参数,具体的释义大家可自行谷歌。此处需要注意,我们将 core 文件生成到了 /tmp 目录下,需要保证其磁盘空间足够大:

我们还需要调整 MySQL 运行用户的 ulimit,在本文中,MySQL 的运行用户是 root,我们调整其 core file 的限制,使其能生成 core dump:

最后,我们要在 MySQL 配置里,允许 MySQL 生成 coredump:

现在我们可以再次运行 MySQL:

可以看到 MySQL 崩溃时,会告知已生成了 core dump 文件。在 error log 中也会有同样的信息:

我们来看一下这个 coredump 文件:

coredump 文件会将崩溃当时的内存情况全部保留下来,所以文件体积会比较大。

在 MySQL 8.0.14 后,MySQL 提供了参数 innodb_buffer_pool_in_core_file,用于将 innodb buffer pool 从 coredump 中排除,用于减小 coredump 的体积。

那我们怎么使用 coredump 文件呢?可以用 gdb 去访问 coredump 文件,获取各种信息,此处举例如何获取所有线程的堆栈信息。

我们会得到一个非常长的堆栈信息,我们截取其中一小段,标注上简单的中文即可看懂。

结论

通过开启操作系统级别、放开用户限制、启用 MySQL 参数三个步骤,我们启用了 MySQL 的 coredump 功能,使得 MySQL 崩溃时留下了足够的线索。

对于复杂崩溃的分析,还是需要将 coredump 交给专业的研发工程师手里,或者提交给 MySQL 开发团队。

不过不管是什么场景,能提供一份 coredump,所有技术人员都会感谢你的。

关于 MySQL 的技术内容,你们还有什么想知道的吗?赶紧留言告诉小编吧!

系统崩溃mysql怎么保存表_第09问:MySQL 莫名崩溃,如何保留现场?相关推荐

  1. mysql实现心跳表_第29问:MySQL 的复制心跳说它不想跳了

    问题 最近年底,大家的数据库经常跑批量大事务,会发现复制突然断开,报错"心跳与本地信息不兼容": 会是什么原因? 实验 我们先来复现一下,再进行分析. 宽油,做一对主从数据库: 我 ...

  2. mysql的slow_log表_【转载】mysql 开启慢查询 清空slow_log日志或者slow_log表

    slow log可以查看系统的sql的执行时间 以及详细的sql,当分析系统性能的时候可以用来参考. 我用到的是这些: mysql> show variables like '%slow%'; ...

  3. 阿里云mysql 分库分表_阿里云rds mysql分库分表

    {"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],&q ...

  4. 如何用mysql创建orders表_《MySQL必知必会》学习笔记

    本书所用的表: 68.png 67.png 66.png 65.png 64.png 63.png 第一章:了解SQL 数据库:保存有组织的数据的容器(通常是一个文件或一组文件). 数据库软件:DBM ...

  5. mysql修复损坏表_在MySQL中,如何修复损坏的表

    本指南旨在作为故障排除资源和诊断MySQL设置的起点. 有时,MySQL表损坏,这意味着发生了错误,并且其中的数据无法读取. 损坏表的一些常见原因是:MySQL服务器在写数据的时候停止.外部程序同时修 ...

  6. python动态生成数据库表_使用Python创建MySQL数据库实现字段动态添加以及动态的插入数据...

    应用场景: 我们须要设计一个数据库来保存多个文档中每一个文档的keyword. 假如我们每一个文档字符都超过了1000,取当中出现频率最大的为我们的keyword. 如果每个文档的keyword都超过 ...

  7. mysql administrator 备份 表_【转】如何使用 MySQL Administrator 管理/备份/还原 My SQL 数据库...

    如何使用 MySQL Administrator 管理/备份/还原 My SQL 数据库 MySQL Administrator 是什么软件? MySQL Administrator 是一个专门用于管 ...

  8. mysql修改工资字段_基于Linux的MySQL操作实例(修改表结构,MySQL索引,MySQL数据引擎)...

    基于Linux的MySQL操作实例(修改表结构,MySQL索引,MySQL数据引擎) 前言 本篇是基于Linux下针对MySQL表结构的修改,MySQL索引的操作以及MySQL数据引擎的配置和说明. ...

  9. mysql select 所有表_怎样用SQL语句查询一个数据库中的所有表

    展开全部 查询32313133353236313431303231363533e59b9ee7ad9431333431356639一个数据库中的所有表sql语句是show tables: 显示所有数据 ...

最新文章

  1. Shift Dot_JAVA
  2. expdp / impdp 用法详解
  3. IP暴露接口IP白名单设置
  4. asp.net 页面静态化
  5. 《图像超分》一些论文走读(SRCNN ,ESPCN ,VDSR ,SRGAN)
  6. 第一篇:NSOperation的概念
  7. 【转】Android用NDK和整套源码下编译JNI的不同
  8. 痛苦如此持久,像蜗牛充满耐心地移动;快乐如此短暂,像兔子的尾巴掠过秋天的草原...
  9. 2、单机运行环境搭建之 --CentOS-6.5安装配置Tomcat8
  10. 颜色分类Python解法
  11. Dell 服务器开启虚拟化功能Intel VT-x
  12. (附源码)springboot教材订购系统的开发毕业设计081419
  13. Java POI实现pptpptx转换为pdf文件
  14. android 8 奕骆,这才是超级手机 奕骆6000mAh称霸全球 USB Type-C
  15. FFmpeg入门详解之12:Elecard Stream Analyzer码流分析工具
  16. 计算机病毒是一种能破坏计算机运行的,计算机病毒是一种能破坏计算机运行的()。...
  17. 逻辑回归三部曲——逻辑回归(logistics regression)原理-让你彻底读懂逻辑回归
  18. python打印hello word_在屏幕上打印输出Hello World,使用的Python语句是( )_学小易找答案...
  19. 章节三:RASA Domain介绍
  20. 基于php的个人图片相册管理系统

热门文章

  1. DataFrame表样式设置(一)
  2. SAP 电商云 Spartacus UI 修改代码后,重新构建基于 SSR 版本的程序报错
  3. Express engine 学习笔记 - 工作在反向代理背后的 Express 设置
  4. Angular 事件绑定语法在 SAP Spartacus Popover Component 中的一个应用
  5. SAP Commerce Cloud 的代码仓库
  6. 一个典型的加了 SAP 注解的 OData 服务明细分析
  7. Angular应用的依赖注入调试
  8. Spark集群的启动日志
  9. SpringBoot里slf4j日志功能的默认实现
  10. How is call from CXF delegated to our application code?