MySQL主从报错解决:Failed to initialize the master info structure

大清早收到一个 MySQL 的自定义语言告警 :replication interrupt,看来是主从同步报错了。
登陆 MySQL,执行 show slave status G 发现 salve 已经停止了,于是使用 start slave 启动,结果有如下报错:

搜索了下,网上给出的解决办法基本都是:①、执行 reset slave;

②、重新执行 change master:

③、执行 start slave

于是试了下,发现还是一样的报错,顺着报错信息,看了下 error 日志:

发现其中频繁出现如下错误:

于是,把 MySQL 数据文件目录下的 index info 文件都看了一遍,结果发现 Centos64-relay-bin.index 文件中出现异常内容:MySQL主从报错解决:Failed to initialize the master info structure

这个文件正常情况应该是记录了 bin-log 文件名称才对,比如:

因此,将 Centos64-relay-bin.index 这个文件 mv 重命名,然后重启 MySQL,重新按照上文从网上照来的的步骤:reset、change master、start 成功搞定!

如果你也遇到类似问题,可以先按照网上提供的三个步骤试试,如果还是和本文类似的报错,请特别看下 MySQL 数据目录下的这几种文件:

mysql-bin.index

relay-log.info

主机名-relay-bin.index

可以尝试将他们重命名或移走,重启 MySQL 再走一遍上面的三个步骤应该可以搞定了!

正文完
 0