Character set '#45' 导致主从停止问题

本文介绍了在MySQL主从环境中因使用低版本不支持的字符集导致同步失败的问题及解决方案。通过排查发现,由于设置了不支持的字符集45,导致从库同步中断。文章详细分析了问题产生的原因,并提供了如何避免此类问题的方法。
部署运行你感兴趣的模型镜像

今天有同学在搭建主从环境的时候发现一个问题,简单说明一下。感谢 @年代80s.

 

       现象:

       从库上Slave_IO_Running停止,Last_Error显示如下:

bin/mysqlbinlog: Character set ‘#45′ is not a compiled character set and is not specified in the ‘/u01/dingqi.lxb/transfer2/master/share/mysql/charsets/Index.xml’ file

 

       分析:

       此时用mysqlbinlog 执行对应的relaylog文件,也会出现上面这个错误提示。 
       查看这个提示位置的Index.xml,这里记录了这个server提供的所有字符集。我们发现,其实没有id为45的字符集。
       也就是这个原因,导致slave在同步时,解析出错,导致同步停止。

        SET @@session.character_set_client=45,@@session.collation_connection=45,@@session.collation_server=33

        从这个命令中看,是有用户连接进master以后,执行了一个set names xxx (xxx是某个字符集名字),而这个xxx被翻译成45.

 

       复现:

       我们要找出编号45的字符集。在5.5上执行如下命令:

       发现原来是这个叫做utf8mb4的字符集,这个字符集在5.1里面是还没有的。

 

       解决:

       给我们的提示就是在高版本对低版本的主从中,要注意不要用到低版本不支持的字符集(所以官方并不建议高版本的master同步到低版本的slave)。

        对于已经在Master的里面已经存在的binlog,要让主从能够继续同步,只能在slave_skip_errors里加上 22这个错误号.

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值