加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL中如何读取Binlog日志

发布时间:2022-02-12 22:11:41 所属栏目:MySql教程 来源:互联网
导读:今天就跟大家聊聊有关MySQL中怎么读取Binlog日志,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 1. mysqlbinlog: [ERROR] unknown variable default-character-set=utf8mb4 当我们在my.cnf中
       今天就跟大家聊聊有关MySQL中怎么读取Binlog日志,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
 
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日志有进一步的了解吗?

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读