当前位置:Gxlcms > 数据库问题 > MySQL读取Binlog日志常见的3种错误

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

时间:2021-07-01 10:21:17 帮助过:13人阅读

 

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种错误

标签:next   选择   数据   span   解决方案   def   div   使用   恢复   

人气教程排行