IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

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

MySQLOPS 数据库与运维自动化技术分享 2012-09-12 23:00:03 累计浏览 2,482 次
本机暂存

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

同分类推荐文章

  1. 使用deepseek进行Oracle恢复,引起重大故障 (2026-06-22 10:56:00)
  2. 接手一个只差临门一脚的数据库恢复 (2026-06-18 00:13:09)
  3. 我做了一个 AI 版的 StarRocks 升级风险扫描工具,直接帮我定位到一个风险 (2026-06-15 01:00:00)

查看更多 数据库 文章 →

建议继续学习

  1. 404~遇见你是最美丽的错误 (累计阅读 9,351)
  2. mysql 主从配置中的server-id的作用 (累计阅读 7,796)
  3. 利用binlog来恢复数据库 (累计阅读 5,202)
  4. 跨机房问题 (累计阅读 4,425)
  5. 多IDC的数据分布设计(一) (累计阅读 4,415)
  6. MySQL在切换binlog时会阻塞更新 (累计阅读 4,080)
  7. 尝试mysqlbinlog的flashback功能 (累计阅读 4,039)
  8. 删除查看二进制日志 (累计阅读 3,900)
  9. 用bin日志中恢复MySQL数据库 (累计阅读 3,761)
  10. Perl 异常处理之 autodie 和 Try::Tiny (累计阅读 3,720)