Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
大炮V587
oceanbase
提交
f419c12e
O
oceanbase
项目概览
大炮V587
/
oceanbase
与 Fork 源项目一致
Fork自
oceanbase / oceanbase
通知
1
Star
0
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,发现更多精彩内容 >>
提交
f419c12e
编写于
3月 15, 2023
作者:
C
chinaxing
提交者:
ob-robot
3月 15, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[master][tx-route] mark static changed when tx switch from IDLE to ABORT
上级
9e1730c4
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
11 addition
and
4 deletion
+11
-4
deps/oblib/src/lib/utility/ob_tracepoint.h
deps/oblib/src/lib/utility/ob_tracepoint.h
+6
-3
src/sql/ob_sql_trans_control.cpp
src/sql/ob_sql_trans_control.cpp
+1
-1
src/storage/tx/ob_trans_service_v4.cpp
src/storage/tx/ob_trans_service_v4.cpp
+4
-0
未找到文件。
deps/oblib/src/lib/utility/ob_tracepoint.h
浏览文件 @
f419c12e
...
...
@@ -672,10 +672,13 @@ class EventTable
EN_FETCH_TABLE_INFO_RPC
=
1112
,
// END OF STORAGE HA - 1101 - 2000
// Transaction // 2001 - 2100
// Transaction free route
EN_TX_FREE_ROUTE_UPDATE_STATE_ERROR
=
1150
,
EN_TX_FREE_ROUTE_ENCODE_STATE_ERROR
=
1151
,
EN_TX_FREE_ROUTE_STATE_SIZE
=
1152
,
EN_TX_FREE_ROUTE_UPDATE_STATE_ERROR
=
2001
,
EN_TX_FREE_ROUTE_ENCODE_STATE_ERROR
=
2002
,
EN_TX_FREE_ROUTE_STATE_SIZE
=
2003
,
// Transaction common
EN_TX_RESULT_INCOMPLETE
=
2011
,
EVENT_TABLE_MAX
=
SIZE_OF_EVENT_TABLE
};
...
...
src/sql/ob_sql_trans_control.cpp
浏览文件 @
f419c12e
...
...
@@ -864,7 +864,7 @@ int ObSqlTransControl::end_stmt(ObExecContext &exec_ctx, const bool rollback)
OX
(
ObTransDeadlockDetectorAdapter
::
maintain_deadlock_info_when_end_stmt
(
exec_ctx
,
rollback
));
auto
&
tx_result
=
session
->
get_trans_result
();
if
(
OB_FAIL
(
ret
))
{
}
else
if
(
tx_result
.
is_incomplete
())
{
}
else
if
(
OB_E
(
EventTable
::
EN_TX_RESULT_INCOMPLETE
,
session
->
get_sessid
())
tx_result
.
is_incomplete
())
{
if
(
!
rollback
)
{
LOG_ERROR
(
"trans result incomplete, but rollback not issued"
);
}
...
...
src/storage/tx/ob_trans_service_v4.cpp
浏览文件 @
f419c12e
...
...
@@ -557,6 +557,10 @@ int ObTransService::abort_tx_(ObTxDesc &tx, const int cause, const bool cleanup)
TRANS_LOG
(
WARN
,
"try abort tx which has decided"
,
K
(
ret
),
K
(
tx
),
K
(
cause
));
}
else
{
// TODO: refactor state switch and put this to there
if
(
ObTxDesc
::
State
::
IDLE
==
tx
.
state_
)
{
tx
.
state_change_flags_
.
STATIC_CHANGED_
=
1
;
}
tx
.
state_
=
ObTxDesc
::
State
::
IN_TERMINATE
;
tx
.
abort_cause_
=
cause
;
abort_participants_
(
tx
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录