加入收藏 | 设为首页 | 会员中心 | 我要投稿 温州站长网 (https://www.0577zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL主从复制错误如何处置

发布时间:2022-01-21 13:21:26 所属栏目:MySql教程 来源:互联网
导读:MySQL主从复制错误如何解决,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 | 背景 有客户咨询说,自己的从库show slave status出现了报错,报错信息显示如下: column 4 of table hh_d
       MySQL主从复制错误如何解决,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
 
| 背景
      有客户咨询说,自己的从库show slave status出现了报错,报错信息显示如下:
 
      column 4 of table 'hh_db_mk.hh_vhl_application'cannot be converted from type 'datetime' to type 'varchar(20)'
 
得到的信息如下:
 
从库停了两天,重启之后新建了这个表,然后就报了这个错。
| 思路
 
看到这个报错,首先想到的是两边表结构是否不一致。查看后发现,表结构一模一样。
 
疑问客户是否有对表结构做了更改,导致了这个报错。但询问客户后,客户表示没有做任何表结构的更改。但同时向客户提出,解析下binlog看一下报错位置的sql语句。当然这个过程花了些时间。
 
出现列转换错误,一般都是由于主从之间字符集不一致导致的。于是询问客户,主从库之间的sql_mode和字符集是否不一致,结果显示均一致。表结构也一致。
  
这个时候,没啥思路了。但还是要求客户解析下binlog看一下对应的sql语句,执行mysqlbinlog -vvv mysql-bin.001744 --start-position=50585341 | head -100。

可以看到,relay-log里面出错点对应的insert语句和目前的表结构确实不一样。报错信息显示的是column 4 cannot be converted from type 'datetime' to type 'varchar(20)',我们知道MySQL中的column是从0开始计数的,所以在relay-log里column 4对应的是第五个字段add_time datetime,在从库表里对应的是第五个字段system_source varchar(20),导致出现了这个报错。
 
| 解决
 
表结构已经发生了变更,让客户重新从主库上拉一份数据到从库,做恢复。
 
| 总结
 
其实这是一个比较简单的问题,但提醒我们,客户的某些确定性的操作不能都信以为真,也有可能客户自己也不知道,或者自己做了什么操作但是却忘记了,以为没有做过。
 
我们要做的,还是要找出真实的情况,以实际为准,不必太纠结于客户的说法。客户的说法不一定正确,不能因此而被误导。

(编辑:温州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读