1. 首页
  2. 技术知识

MySQL读取Binlog日志常见的3种错误

1. mysqlbinlog: [ERROR] unknown variable ‘default-character-set=utf8mb4’

当我们在my.cnf中添加default-character-set=utf8mb4选项,那么在mysqlbinlog查看binlog时就会报错。

解决方案:.mysqlbinlog 后面添加 –no-defaults 选项

例如:

mysql bin可执行文件所在路径/bin/mysqlbinlog –no-defaults binlog所在目录/mysql_bin.000005


2.ERROR 1840 (HY000) at line 24: @@GLOBAL.GTID_PURGED can only be set when @@GLOBAL.GTID_EXECUTED is empty.

在进行mysqldump导出数据,进行数据库迁移。而在迁入时,报了上面的错误。

查询原因是 :当前GTID_EXECUTED参数已经有值,而从源数据库中倒出来的dump文件中包含了SET @@GLOBAL.GTID_PURGED的操作


解决方法:


方法一:reset mater

这个操作可以将当前库的GTID_EXECUTED值置空


方法二:–set-gtid-purged=off

在dump导出时,添加–set-gtid-purged=off参数,避免将gtid信息导出

mysqldump  –set-gtid-purged=off -d dbtest > dbtest.sql


3.ERROR 1782 (HY000) at line 23: @@SESSION.GTID_NEXT cannot be set to ANONYMOUS when @@GLOBAL.GTID_MODE = ON.

当我们在使用 mysqlbinlog 工具进行 指定–stop-position 、–start-position 进行恢复(部分恢复)时报的错。

例如,binlog中的数据如下:

当我们选择的开始点是  Query 对应的 Pos (713),,而不是 Gtid对应的Pos(648)就会报错。

下面的写法报错:

安装路径/bin/mysqlbinlog  –no-defaults –start-position=713 –stop-position=1646

下面的写法没有报错:

安装路径/bin/mysqlbinlog  –no-defaults –start-position=648 –stop-position=1646 ………

总结

以上所述是小编给大家介绍的MySQL读取Binlog日志常见的3种错误,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对共生网络网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

原创文章,作者:starterknow,如若转载,请注明出处:https://www.starterknow.com/115594.html

联系我们