- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章MySQL 实例无法启动的问题分析及解决由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
前言 。
前几天,有位朋友微信联系我,告知一个生产数据库,在机器宕机恢复后,实例启动失败,而且该实例没有做任何的高可用、容灾、备份等,对业务影响非常大,希望能够协助排查一下,我也在第一时间就加入到排查中.
场景分析 。
(1)首先查看错误日志,报错很清晰"could not open log file",无法打开日志文件 。
1
2
3
4
|
2021-01-06 13:23:51 20464 [error] failed
to
open
log (file
'something is definitely wrong and this may fail.'
, errno 2)
2021-01-06 13:23:51 20464 [error] could
not
open
log file
2021-01-06 13:23:51 20464 [error] can't init tc log
2021-01-06 13:23:51 20464 [error] aborting
|
(2)看到上述报错后,当然就应该想到,检查下my.cnf配置是否正确、日志目录和权限是否正确,但排查并未发现问题 。
1
2
3
4
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
|
# less my.cnf
datadir=/var/lib/mysql
log-bin=mysql-bin
relay-log=relay-bin
# ls -lrt
-rw-rw
---- 1 mysql mysql 1073761373 jan 4 06:18 mysql-bin.007351
-rw-rw
---- 1 mysql mysql 1073755587 jan 4 09:26 mysql-bin.007352
-rw-rw
---- 1 mysql mysql 1073777045 jan 4 12:07 mysql-bin.007353
-rw-rw
---- 1 mysql mysql 1073742801 jan 4 15:12 mysql-bin.007354
-rw-rw
---- 1 mysql mysql 1074087344 jan 4 18:13 mysql-bin.007355
-rw-rw
---- 1 mysql mysql 1073869414 jan 4 21:32 mysql-bin.007356
-rw-rw
---- 1 mysql mysql 1073771900 jan 5 00:16 mysql-bin.007357
-rw-rw
---- 1 mysql mysql 213063247 jan 5 01:00 mysql-bin.007358
-rw-rw
---- 1 mysql mysql 1073753668 jan 5 02:11 mysql-bin.007359
-rw-rw
---- 1 mysql mysql 671219722 jan 5 03:31 mysql-bin.007360
-rw-rw
---- 1 mysql mysql 1073774928 jan 5 07:34 mysql-bin.007361
-rw-rw
---- 1 mysql mysql 1073845285 jan 5 11:33 mysql-bin.007362
-rw-rw
---- 1 mysql mysql 1073756444 jan 5 15:37 mysql-bin.007363
-rw-rw
---- 1 mysql mysql 1073790555 jan 5 19:37 mysql-bin.007364
-rw-rw
---- 1 mysql mysql 1073768027 jan 5 23:59 mysql-bin.007365
-rw-rw
---- 1 mysql mysql 311398643 jan 6 01:00 mysql-bin.007366
-rw-rw
---- 1 mysql mysql 1071242043 jan 6 03:31 mysql-bin.007367
-rw-rw
---- 1 mysql mysql 1010516229 jan 6 07:27 mysql-bin.007368
-rw-rw
---- 1 mysql mysql 1651 jan 6 07:27 mysql-bin.index
-rw-rw
---- 1 mysql mysql 1073741824 jan 6 12:08 ib_logfile1
-rw-r
--r-- 1 mysql mysql 183 jan 6 13:23 vm_58_10_centos-slow.log
-rw-rw
---- 1 mysql mysql 1073741824 jan 6 13:23 ib_logfile0
-rw-rw
---- 1 mysql mysql 7492941 jan 6 13:23 vm_58_10_centos.err
|
(3)报错有一个非常奇怪的点,file 'something is definitely wrong and this may fail.' ,为什么日志文件名会那么奇怪呢?这里需要知道的是,mysql-bin.index记录了binlog相关信息,mysql实例启动时需要读取该文件获取信息;那接下来就检查一下该文件,发现果然有问题,mysql-bin.index后半部分错误写入了错误日志的内容,从而导致实例启动时读取到错误内容(当作binlog日志文件进行处理)报错失败 。
1
2
3
4
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
41
42
43
44
|
# cat mysql-bin.
index
./mysql-bin.007351
./mysql-bin.007352
./mysql-bin.007353
./mysql-bin.007354
./mysql-bin.007355
./mysql-bin.007356
./mysql-bin.007357
./mysql-bin.007358
./mysql-bin.007359
./mysql-bin.007360
./mysql-bin.007361
./mysql-bin.007362
./mysql-bin.007363
./mysql-bin.007364
./mysql-bin.007365
./mysql-bin.007366
./mysql-bin.007367
./mysql-bin.007368
23:27:31 utc - mysqld got signal 6 ;
this could be because you hit a bug. it
is
also possible that this
binary
or
one
of
the libraries it was linked against
is
corrupt, improperly built,
or
misconfigured. this error can also be caused
by
malfunctioning hardware.
we will try our best
to
scrape up
some
info that will hopefully help
diagnose the problem, but since we have already crashed,
something
is
definitely wrong
and
this may fail.
key_buffer_size=16777216
read_buffer_size=3145728
max_used_connections=523
max_threads=800
thread_count=522
connection_count=522
it
is
possible that mysqld could use up
to
key_buffer_size + (read_buffer_size + sort_buffer_size)*max_threads = 9037821 k bytes
of
memory
hope that's ok; if
not
, decrease
some
variables
in
the equation.
thread pointer: 0x0
attempting backtrace. you can use the following information
to
find
out
where
mysqld died. if you see
no
messages
after
this, something went
terribly wrong...
stack_bottom = 0 thread_stack 0x40000
the manual page
at
http://dev.mysql.com/doc/mysql/en/crashing.html
contains
information that should help you find
out
what
is
causing the crash.
|
(4)原因定位后,解决办法就是将mysql-bin.index文件备份后,手动进行修复,随后启动实例成功 。
1
2
3
4
5
6
7
8
|
# ./mysql start
starting mysql.... success!
checking mysql
connection
:
connection
ok!
# ps -ef | grep mysqld
root 22955 1 0 13:30 pts/5 00:00:00 /bin/sh /usr/bin/mysqld_safe
--datadir=/var/lib/mysql --pid-file=/var/lib/mysql/vm_58_10_centos.pid
mysql 23733 22955 24 13:30 pts/5 00:00:05 /usr/sbin/mysqld
--basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib64/mysql/plugin --user=mysql --log-error=/var/lib/mysql/vm_58_10_centos.err --open-files-limit=20000 --pid-file=/var/lib/mysql/vm_58_10_centos.pid --socket=/var/lib/mysql/mysql.sock --port=3306
root 32075 14929 0 13:30 pts/5 00:00:00 grep mysqld
|
总结 。
至此,问题得到解决,至于为什么错误日志内容会写入到mysql-bin.index,个人怀疑是宕机导致文件错乱(该宿主机上的其他虚拟机有出现文件系统损坏的情况);最后,还是得强调一下,生产系统还是得重视起来,备份、高可用、容灾都是不可或缺的.
以上就是mysql 实例无法启动的问题分析及解决的详细内容,更多关于mysql 实例无法启动的资料请关注我其它相关文章! 。
原文链接:https://cloud.tencent.com/developer/inventory/2101/article/1769876 。
最后此篇关于MySQL 实例无法启动的问题分析及解决的文章就讲到这里了,如果你想了解更多关于MySQL 实例无法启动的问题分析及解决的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
每当我运行命令以将 Virtualbox 驱动程序启动 Minishift 到操作系统主机时,它都需要一段疯狂的时间,而且它永远不会结束。有时我什至收到有关达到存储限制的错误消息。 不知道是不是描述h
您好,我正在使用 npm 运行一个基本的 React 项目,我正尝试在 docker 容器中启动它。但是我实际上无法让项目运行。我的 dockerfile 看起来像这样: FROM node:7.8.
所以我想从我的 SSH 终端开始游戏。 这真的很奇怪,当我直接从 Linux GUI 执行此操作时,它可以工作。但是当我使用 SSH 客户端进行远程连接时,它就崩溃了。似乎与我的显示驱动程序有关。 U
我有一个显示图像的动态壁纸。我在 Activity 中更改了该图像。然后我需要通知动态壁纸,以便它知道重新加载资源。 Intent 似乎是完美、简单的解决方案: Intent intent = new
我有一个似乎无法解决的问题。我在 Boot Dashboard 中使用 STS 3.9.2 从 Eclipse (Oxygen) 启动 Spring Boot 应用程序没有任何问题: 但是,当我尝试从
全新的 Python,在我开始摆弄东西之前先设置和安装东西。我的理解是 Python 2.7 和 Python 3.3 之间存在一些显着差异/不兼容,尽管这两个版本都得到了很好的使用,所以我认为最好安
在使用了很长时间的 jQuery 之后,我有一个问题,我正在使用 jQuery 模式(样式)编写一个简单的代码, (function(window, undefined) { var jQu
我正在尝试在 spring boot 应用程序下的非 spring 托管类中配置 Autowired。我在 tomcat 服务器下部署的 Web 应用程序下成功运行了这个。但是当我想在 spring
我对 xmonad 完全陌生,但我想开始使用它来提高我的工作效率。 这是我一直在使用的指南(我使用的是 Apple OS X Snow Leopard) http://xmonad.org/tour.
我试图将Spring Boot指南中的Managing Transactions示例扩展到两个数据源,但是@Transaction注释似乎仅对其中一个数据源有效。 在“Application.java
conEmu 有没有办法默认打开多个不同的选项卡? 我看到这个页面解释了如何使用 splits , 我意识到我可以按 Ctrl + T, 1, Enter,但我希望有一种方法可以自动执行此操作! "%
我正在寻找快速而肮脏的答案。我当时脑子一片空白,盯着屏幕看了 12 个小时以上,我想我中枪了。 我想做一个简单的 SignalR 应用程序作为教程。我找到了这个example ,但我不断收到票证未定义
我正在使用 Azure Powershell cmdlet 来启动/停止 VM。 Start-AzureVM [-ServiceName] [-Name] [ ] Stop-AzureVM [-S
我想使用Powershell脚本代码启动/停止iis和mssql 意味着当我运行ps脚本时,我想启动/停止iis和mssql 我在网上搜索了它,发现了一些代码,但按照我的要求无法正常工作 码: $ii
我在 liferay 工作。我们在我们的项目中使用一个模块来创建 liferay 主题。我使用命令 ant -Ddeploy.war=true 将它部署在服务器中。 war 文件在 liferay 部
我想在已安装 Python 2.7 的 Windows XP 计算机上运行 IPython(版本 0.12)。 我通过 Windows 二进制安装程序安装,但安装后 IPython 没有显示在菜单中,
我从创建了自己的简单图片。 FROM python:2.7.11 RUN mkdir /extra/later/ \ && mkdir /yyy 现在,我可以执行以下步骤: docker run
$(document).ready(function () { setTimeout(function() { window.location.reload(); }, 2000); // 2
我刚刚创建了一个帐户 OpenWeatherMap 我想通过城市 ID API 调用获取当前位置的天气: http://api.openweathermap.org/data/2.5/weather?
我注意到,如果我更改 xcasset 中的图像,启动 Storyboard不会更新。 例如,假设您的启动 Storyboard中有一个 UIImage View ,其中包含一个名为“logo”的蓝色图
我是一名优秀的程序员,十分优秀!