Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
apache
Shardingsphere
提交
bba56f6e
Shardingsphere
项目概览
apache
/
Shardingsphere
通知
56
Star
3
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
Shardingsphere
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
bba56f6e
编写于
10月 08, 2019
作者:
A
avalon566
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fixed rotate event checksum
上级
ffb23d2e
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
21 addition
and
3 deletion
+21
-3
src/main/java/info/avalon566/shardingscaling/sync/mysql/binlog/MySQLConnector.java
...566/shardingscaling/sync/mysql/binlog/MySQLConnector.java
+15
-1
src/main/java/info/avalon566/shardingscaling/sync/mysql/binlog/codec/MySQLBinlogEventPacketDecoder.java
...ync/mysql/binlog/codec/MySQLBinlogEventPacketDecoder.java
+6
-2
未找到文件。
src/main/java/info/avalon566/shardingscaling/sync/mysql/binlog/MySQLConnector.java
浏览文件 @
bba56f6e
...
...
@@ -189,6 +189,7 @@ public final class MySQLConnector {
*/
public
synchronized
void
subscribe
(
final
String
binlogFileName
,
final
long
binlogPosition
)
{
initDumpConnectSession
();
int
checksumLength
=
queryChecksumLength
();
registerSlave
();
responseCallback
=
null
;
BinlogDumpCommandPacket
binlogDumpCmd
=
new
BinlogDumpCommandPacket
();
...
...
@@ -197,11 +198,24 @@ public final class MySQLConnector {
binlogDumpCmd
.
setSlaveServerId
(
serverId
);
channel
.
pipeline
().
remove
(
MySQLCommandPacketDecoder
.
class
);
channel
.
pipeline
().
remove
(
MySQLCommandResponHandler
.
class
);
channel
.
pipeline
().
addLast
(
new
MySQLBinlogEventPacketDecoder
());
channel
.
pipeline
().
addLast
(
new
MySQLBinlogEventPacketDecoder
(
checksumLength
));
channel
.
pipeline
().
addLast
(
new
MySQLBinlogEventHandler
());
channel
.
writeAndFlush
(
binlogDumpCmd
);
}
private
int
queryChecksumLength
()
{
InternalResultSet
resultSet
=
executeQuery
(
"select @@global.binlog_checksum"
);
String
checksumType
=
resultSet
.
getFieldValues
().
get
(
0
).
getColumns
().
get
(
0
);
switch
(
checksumType
)
{
case
"None"
:
return
0
;
case
"CRC32"
:
return
4
;
default
:
throw
new
UnsupportedOperationException
();
}
}
/**
* Poll binlog event.
*
...
...
src/main/java/info/avalon566/shardingscaling/sync/mysql/binlog/codec/MySQLBinlogEventPacketDecoder.java
浏览文件 @
bba56f6e
...
...
@@ -43,7 +43,12 @@ import java.util.List;
@Slf4j
public
final
class
MySQLBinlogEventPacketDecoder
extends
ByteToMessageDecoder
{
private
final
BinlogContext
binlogContext
=
new
BinlogContext
();
private
final
BinlogContext
binlogContext
;
public
MySQLBinlogEventPacketDecoder
(
int
checksumLength
)
{
binlogContext
=
new
BinlogContext
();
binlogContext
.
setChecksumLength
(
checksumLength
);
}
@Override
protected
void
decode
(
final
ChannelHandlerContext
ctx
,
final
ByteBuf
in
,
final
List
<
Object
>
out
)
{
...
...
@@ -99,7 +104,6 @@ public final class MySQLBinlogEventPacketDecoder extends ByteToMessageDecoder {
private
void
removeChecksum
(
final
short
eventType
,
final
ByteBuf
in
)
{
if
(
0
<
binlogContext
.
getChecksumLength
()
&&
EventTypes
.
ROTATE_EVENT
!=
eventType
&&
EventTypes
.
FORMAT_DESCRIPTION_EVENT
!=
eventType
)
{
in
.
writerIndex
(
in
.
writerIndex
()
-
binlogContext
.
getChecksumLength
());
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录