Character set ‘#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
分析:
此时用MySQL数据库自带的工具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这个错误号。
建议继续学习:
- mysql 主从配置中的server-id的作用 (阅读:7300)
- 内存表在同步环境注意事项 (阅读:5297)
- 也谈PostgreSQL的同步配置(Slony) (阅读:5143)
- MySQL5.5数据库复制搭建报错之Could not initialize master info structure (阅读:4988)
- PHP查询MySQL大量数据的内存占用分析 (阅读:4619)
- MTU值的调整导致MySQL复制异常 (阅读:4351)
- MySQL复制的概述、安装、故障、技巧、工具 (阅读:3899)
- 自己动手实现Multi-Master Replication (阅读:3547)
- mysql主从同步快速设置 (阅读:3539)
- mysql主从热备配置(含innodb)终极版 (阅读:3510)
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:丁奇 来源: MySQLOPS 数据库与运维自动化技术分享
- 标签: 主从同步
- 发布时间:2012-09-12 23:00:03
-
[928] WordPress插件开发 -- 在插件使用 -
[134] 解决 nginx 反向代理网页首尾出现神秘字 -
[52] 整理了一份招PHP高级工程师的面试题 -
[52] 如何保证一个程序在单台服务器上只有唯一实例( -
[51] 用 Jquery 模拟 select -
[50] 海量小文件存储 -
[50] Innodb分表太多或者表分区太多,会导致内 -
[50] 全站换域名时利用nginx和javascri -
[49] CloudSMS:免费匿名的云短信 -
[47] jQuery性能优化指南

