Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
野花太放肆
oceanbase
提交
9407bbea
O
oceanbase
项目概览
野花太放肆
/
oceanbase
与 Fork 源项目一致
Fork自
oceanbase / oceanbase
通知
1
Star
1
Fork
0
代码
文件
提交
分支
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,发现更多精彩内容 >>
提交
9407bbea
编写于
3月 22, 2023
作者:
O
obdev
提交者:
ob-robot
3月 22, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix dtl interm result leak when use vectorized spf and px batch rescan
上级
ef75f54b
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
8 addition
and
2 deletion
+8
-2
src/sql/dtl/ob_dtl_interm_result_manager.cpp
src/sql/dtl/ob_dtl_interm_result_manager.cpp
+1
-0
src/sql/engine/px/ob_px_coord_op.cpp
src/sql/engine/px/ob_px_coord_op.cpp
+6
-2
src/sql/engine/px/ob_px_coord_op.h
src/sql/engine/px/ob_px_coord_op.h
+1
-0
未找到文件。
src/sql/dtl/ob_dtl_interm_result_manager.cpp
浏览文件 @
9407bbea
...
...
@@ -396,6 +396,7 @@ int ObDTLIntermResultManager::generate_monitor_info_rows(observer::ObDTLIntermRe
if
(
OB_FAIL
(
map_
.
foreach_refactored
(
monitor_info_getter
)))
{
LOG_WARN
(
"fail to generate monitor info array from map"
,
K
(
ret
));
}
LOG_TRACE
(
"generate monitor info rows"
,
K
(
ret
),
K
(
map_
.
size
()));
return
ret
;
}
...
...
src/sql/engine/px/ob_px_coord_op.cpp
浏览文件 @
9407bbea
...
...
@@ -132,7 +132,8 @@ ObPxCoordOp::ObPxCoordOp(ObExecContext &exec_ctx, const ObOpSpec &spec, ObOpInpu
px_dop_
(
1
),
time_recorder_
(
0
),
batch_rescan_param_version_
(
0
),
server_alive_checker_
(
coord_info_
.
dfo_mgr_
,
exec_ctx
.
get_my_session
()
->
get_process_query_time
())
server_alive_checker_
(
coord_info_
.
dfo_mgr_
,
exec_ctx
.
get_my_session
()
->
get_process_query_time
()),
last_px_batch_rescan_size_
(
0
)
{}
...
...
@@ -889,6 +890,7 @@ int ObPxCoordOp::receive_channel_root_dfo(
if
(
enable_px_batch_rescan
())
{
ch
->
set_interm_result
(
true
);
ch
->
set_batch_id
(
get_batch_id
());
last_px_batch_rescan_size_
=
max
(
get_batch_id
()
+
1
,
get_rescan_param_count
());
}
}
LOG_TRACE
(
"link qc-task channel and registered to qc msg loop. ready to receive task data msg"
,
...
...
@@ -961,6 +963,7 @@ int ObPxCoordOp::receive_channel_root_dfo(
if
(
enable_px_batch_rescan
())
{
ch
->
set_interm_result
(
true
);
ch
->
set_batch_id
(
get_batch_id
());
last_px_batch_rescan_size_
=
max
(
get_batch_id
()
+
1
,
get_rescan_param_count
());
}
}
LOG_TRACE
(
"link qc-task channel and registered to qc msg loop. ready to receive task data msg"
,
...
...
@@ -1049,12 +1052,13 @@ int ObPxCoordOp::erase_dtl_interm_result()
LOG_WARN
(
"fail get channel info"
,
K
(
ret
));
}
else
{
key
.
channel_id_
=
ci
.
chid_
;
for
(
int
j
=
0
;
j
<
max
(
get_batch_id
()
+
1
,
get_rescan_param_count
())
;
++
j
)
{
for
(
int
j
=
0
;
j
<
last_px_batch_rescan_size_
;
++
j
)
{
key
.
batch_id_
=
j
;
if
(
OB_FAIL
(
ObDTLIntermResultManager
::
getInstance
().
erase_interm_result_info
(
key
)))
{
LOG_TRACE
(
"fail to release recieve internal result"
,
K
(
ret
));
}
}
last_px_batch_rescan_size_
=
0
;
}
}
}
...
...
src/sql/engine/px/ob_px_coord_op.h
浏览文件 @
9407bbea
...
...
@@ -159,6 +159,7 @@ protected:
int64_t
time_recorder_
;
int64_t
batch_rescan_param_version_
;
ObExtraServerAliveCheck
server_alive_checker_
;
int64_t
last_px_batch_rescan_size_
;
};
class
ObPxCoordSpec
:
public
ObPxReceiveSpec
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录