系统崩溃mysql怎么保存表_第09问:MySQL 莫名崩溃,如何保留现场?
问题
我的 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 莫名崩溃,如何保留现场?相关推荐
- mysql实现心跳表_第29问:MySQL 的复制心跳说它不想跳了
问题 最近年底,大家的数据库经常跑批量大事务,会发现复制突然断开,报错"心跳与本地信息不兼容": 会是什么原因? 实验 我们先来复现一下,再进行分析. 宽油,做一对主从数据库: 我 ...
- mysql的slow_log表_【转载】mysql 开启慢查询 清空slow_log日志或者slow_log表
slow log可以查看系统的sql的执行时间 以及详细的sql,当分析系统性能的时候可以用来参考. 我用到的是这些: mysql> show variables like '%slow%'; ...
- 阿里云mysql 分库分表_阿里云rds mysql分库分表
{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],&q ...
- 如何用mysql创建orders表_《MySQL必知必会》学习笔记
本书所用的表: 68.png 67.png 66.png 65.png 64.png 63.png 第一章:了解SQL 数据库:保存有组织的数据的容器(通常是一个文件或一组文件). 数据库软件:DBM ...
- mysql修复损坏表_在MySQL中,如何修复损坏的表
本指南旨在作为故障排除资源和诊断MySQL设置的起点. 有时,MySQL表损坏,这意味着发生了错误,并且其中的数据无法读取. 损坏表的一些常见原因是:MySQL服务器在写数据的时候停止.外部程序同时修 ...
- python动态生成数据库表_使用Python创建MySQL数据库实现字段动态添加以及动态的插入数据...
应用场景: 我们须要设计一个数据库来保存多个文档中每一个文档的keyword. 假如我们每一个文档字符都超过了1000,取当中出现频率最大的为我们的keyword. 如果每个文档的keyword都超过 ...
- mysql administrator 备份 表_【转】如何使用 MySQL Administrator 管理/备份/还原 My SQL 数据库...
如何使用 MySQL Administrator 管理/备份/还原 My SQL 数据库 MySQL Administrator 是什么软件? MySQL Administrator 是一个专门用于管 ...
- mysql修改工资字段_基于Linux的MySQL操作实例(修改表结构,MySQL索引,MySQL数据引擎)...
基于Linux的MySQL操作实例(修改表结构,MySQL索引,MySQL数据引擎) 前言 本篇是基于Linux下针对MySQL表结构的修改,MySQL索引的操作以及MySQL数据引擎的配置和说明. ...
- mysql select 所有表_怎样用SQL语句查询一个数据库中的所有表
展开全部 查询32313133353236313431303231363533e59b9ee7ad9431333431356639一个数据库中的所有表sql语句是show tables: 显示所有数据 ...
最新文章
- Shift Dot_JAVA
- expdp / impdp 用法详解
- IP暴露接口IP白名单设置
- asp.net 页面静态化
- 《图像超分》一些论文走读(SRCNN ,ESPCN ,VDSR ,SRGAN)
- 第一篇:NSOperation的概念
- 【转】Android用NDK和整套源码下编译JNI的不同
- 痛苦如此持久,像蜗牛充满耐心地移动;快乐如此短暂,像兔子的尾巴掠过秋天的草原...
- 2、单机运行环境搭建之 --CentOS-6.5安装配置Tomcat8
- 颜色分类Python解法
- Dell 服务器开启虚拟化功能Intel VT-x
- (附源码)springboot教材订购系统的开发毕业设计081419
- Java POI实现pptpptx转换为pdf文件
- android 8 奕骆,这才是超级手机 奕骆6000mAh称霸全球 USB Type-C
- FFmpeg入门详解之12:Elecard Stream Analyzer码流分析工具
- 计算机病毒是一种能破坏计算机运行的,计算机病毒是一种能破坏计算机运行的()。...
- 逻辑回归三部曲——逻辑回归(logistics regression)原理-让你彻底读懂逻辑回归
- python打印hello word_在屏幕上打印输出Hello World,使用的Python语句是( )_学小易找答案...
- 章节三:RASA Domain介绍
- 基于php的个人图片相册管理系统
热门文章
- DataFrame表样式设置(一)
- SAP 电商云 Spartacus UI 修改代码后,重新构建基于 SSR 版本的程序报错
- Express engine 学习笔记 - 工作在反向代理背后的 Express 设置
- Angular 事件绑定语法在 SAP Spartacus Popover Component 中的一个应用
- SAP Commerce Cloud 的代码仓库
- 一个典型的加了 SAP 注解的 OData 服务明细分析
- Angular应用的依赖注入调试
- Spark集群的启动日志
- SpringBoot里slf4j日志功能的默认实现
- How is call from CXF delegated to our application code?