Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
oceanbase
oceanbase
提交
c2f15e3a
O
oceanbase
项目概览
oceanbase
/
oceanbase
10 个月 前同步成功
通知
261
Star
6084
Fork
1301
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
oceanbase
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
c2f15e3a
编写于
10月 26, 2022
作者:
O
obdev
提交者:
wangzelin.wzl
10月 26, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix ddl use major merge sstable to report checksum
上级
b9374c48
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
11 addition
and
12 deletion
+11
-12
src/storage/ddl/ob_ddl_merge_task.cpp
src/storage/ddl/ob_ddl_merge_task.cpp
+11
-12
未找到文件。
src/storage/ddl/ob_ddl_merge_task.cpp
浏览文件 @
c2f15e3a
...
...
@@ -320,8 +320,7 @@ int ObDDLTableMergeTask::process()
LOG_WARN
(
"check if major sstable exist failed"
,
K
(
ret
));
}
else
if
(
is_major_sstable_exist
)
{
LOG_INFO
(
"major sstable has been created before"
,
K
(
merge_param_
),
K
(
ddl_param
.
table_key_
));
// TODO(cangdi): after compacting ddl sstable, a major compaction occurs, which may lead to checksum error
sstable
=
static_cast
<
ObSSTable
*>
(
tablet_handle
.
get_obj
()
->
get_table_store
().
get_major_sstables
().
get_boundary_table
(
true
/*last*/
));
sstable
=
static_cast
<
ObSSTable
*>
(
tablet_handle
.
get_obj
()
->
get_table_store
().
get_major_sstables
().
get_boundary_table
(
false
/*first*/
));
}
else
if
(
tablet_handle
.
get_obj
()
->
get_tablet_meta
().
table_store_flag_
.
with_major_sstable
())
{
skip_major_process
=
true
;
LOG_INFO
(
"tablet me says with major but no major, meaning its a migrated deleted tablet, skip"
);
...
...
@@ -611,17 +610,17 @@ int ObTabletDDLUtil::create_ddl_sstable(ObSSTableIndexBuilder *sstable_index_bui
}
else
{
const
int64_t
rebuild_seq
=
ls_handle
.
get_ls
()
->
get_rebuild_seq
();
ObTabletHandle
new_tablet_handle
;
ObUpdateTableStoreParam
param
(
table_handle
,
tablet_handle
.
get_obj
()
->
get_snapshot_version
(),
ddl_param
.
table_key_
.
is_major_sstable
()
?
false
:
true
,
// keep_old_ddl_sstable
&
storage_schema
,
rebuild_seq
,
ddl_param
.
table_key_
.
is_major_sstable
()
?
true
:
false
,
// update_with_major_flag
ddl_param
.
table_key_
.
is_major_sstable
()
?
true
:
false
);
// need report checksum
if
(
OB_FAIL
(
ls_handle
.
get_ls
()
->
update_tablet_table_store
(
ddl_param
.
table_key_
.
get_tablet_id
(),
param
,
new_tablet_handle
)))
{
LOG_WARN
(
"failed to update tablet table store"
,
K
(
ret
),
K
(
ddl_param
.
table_key_
),
K
(
param
));
ObUpdateTableStoreParam
table_store_
param
(
table_handle
,
tablet_handle
.
get_obj
()
->
get_snapshot_version
(),
ddl_param
.
table_key_
.
is_major_sstable
()
?
false
:
true
,
// keep_old_ddl_sstable
&
storage_schema
,
rebuild_seq
,
ddl_param
.
table_key_
.
is_major_sstable
()
?
true
:
false
,
// update_with_major_flag
ddl_param
.
table_key_
.
is_major_sstable
()
?
true
:
false
);
// need report checksum
if
(
OB_FAIL
(
ls_handle
.
get_ls
()
->
update_tablet_table_store
(
ddl_param
.
table_key_
.
get_tablet_id
(),
table_store_
param
,
new_tablet_handle
)))
{
LOG_WARN
(
"failed to update tablet table store"
,
K
(
ret
),
K
(
ddl_param
.
table_key_
),
K
(
table_store_
param
));
}
else
{
LOG_INFO
(
"create ddl sstable success"
,
K
(
ddl_param
),
K
(
param
));
LOG_INFO
(
"create ddl sstable success"
,
K
(
ddl_param
),
K
(
param
)
,
K
(
table_store_param
)
);
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录