#MySql-Binlog协议详解-报文篇

紧接上篇流程篇,本篇主要将binlog的event报文。

##Event报文分层

event报文主要分三层。

(1)MySql报文都有的length-body防粘包结构。

(2)Event Header

(2)Event Body

总体结构如下图所示:

926fe7befaa1c4b80dda5c60450c8b7c.png

##EventHeader

Event Header结构如下图所示:

64100b8e4af4fe6d997d311f903addf7.png

(1)前4比特,是当前binlogEvent发生的时间戳

(2)1byte的event类型,详情见github

(3)4byte的serverId,是发送event的主库标识

(4)4byte的event_length,是指包含当前eventHeader的整个body的长度

(5)最后2byte是标志位

解EventHeader报文的代码如下所示:

public void read() {

timestamp = mm.readUB4() * 1000;

eventType = getEventType(mm.read());

serverId = mm.readUB4();

eventLength = mm.readUB4();

nextPosition = mm.readUB4();

flags = mm.readUB2();

}

EventBody

紧接着就是描述EventBody。EventBody根据类型分主要有:

(1)RotateEventData:当MySql的binlog文件从file1滚动到file2的时候会发生此事件。

(2)UpdateRowsEventData:当binlog格式设置的是Row|mixed且Row更新的时候会发生此事件。

(3)QueryEventData:当binlog格式设置的是statement|mixed且做DB有了更新、插入或删除操作的时候会发生时间(例如修改Row,alter表等)。

(4)WriteRowsEventData:当binlog格式设置的是Row|mixed且有insert操作时候,有此事件发生。

(5)余下还有不少event格式,在此就不一一罗列了,具体见github

RotateEventData

64100b8e4af4fe6d997d311f903addf7.png

(1)8byte的binlogPosition

(2)以0x00结尾的String,表示了当前binlog文件名

###UpdateRowsEventData

abbabd02a434ff0c525ac93897ebcf1f.png

(1)byte的tableId,表明唯一一张表

(2)一个复杂的Bit集合,有更新的Row在更新之前的值在下面Row列表中的位置

(3)一个复杂的Bit集合,有更新的Row在更新之后的值在下面Row列表中的位置

(4)一个Row的列表,配合上面两个bitSet使用

具体解析BitSet非常复杂,详情见github

###QueryEventData

d0f23643818e117c1932357bdad148fc.png

(1)4bytes的线程id

(2)4bytes的当前事件执行时间

(3)1bytes的数据库名字长度

(4)2bytes的errorCode

(5)2bytes的statusVar长度

(6)statusVar

(7)以0x00结尾的数据库名称

(8)以0x00皆为的执行SQL,例如update t_temp set name='123' where id=1

###WriteRowsEventData

870c4f41a51942a0f9db941bd9bf8ca9.png

(1)8bytes的tableId

(2)一个复杂的Bit集合,和下面的Row配合使用

(3)一个Row的列表,表明了插入的行

由于上述几个eventData解析都很复杂,详情请见github

github地址

原文链接

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐