视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Characterset'#45'导致主从停止问题
2020-11-09 09:41:49 责编:小采
文档


今天有同学在搭建主从环境的时候发现一个问题,简单说明一下。感谢 @年代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/

今天有同学在搭建主从环境的时候发现一个问题,简单说明一下。感谢 @年代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这个错误号.

下载本文
显示全文
专题