Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
04f94198
T
TDengine
项目概览
taosdata
/
TDengine
大约 1 年 前同步成功
通知
1184
Star
22015
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
04f94198
编写于
8月 25, 2022
作者:
C
Cary Xu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: free stream/sma obj in trans
上级
5ce84e43
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
28 addition
and
0 deletion
+28
-0
source/dnode/mnode/impl/src/mndTrans.c
source/dnode/mnode/impl/src/mndTrans.c
+8
-0
source/dnode/mnode/sdb/inc/sdb.h
source/dnode/mnode/sdb/inc/sdb.h
+1
-0
source/dnode/mnode/sdb/src/sdb.c
source/dnode/mnode/sdb/src/sdb.c
+19
-0
未找到文件。
source/dnode/mnode/impl/src/mndTrans.c
浏览文件 @
04f94198
...
...
@@ -800,6 +800,11 @@ static bool mndCheckTransConflict(SMnode *pMnode, STrans *pNew) {
return
conflict
;
}
static
void
mndTransFreeObj
(
SSdb
*
pSdb
)
{
sdbFreeRowsByType
(
pSdb
,
SDB_STREAM
);
sdbFreeRowsByType
(
pSdb
,
SDB_SMA
);
}
int32_t
mndTransPrepare
(
SMnode
*
pMnode
,
STrans
*
pTrans
)
{
if
(
pTrans
->
conflict
==
TRN_CONFLICT_DB
||
pTrans
->
conflict
==
TRN_CONFLICT_DB_INSIDE
)
{
if
(
strlen
(
pTrans
->
dbname1
)
==
0
&&
strlen
(
pTrans
->
dbname2
)
==
0
)
{
...
...
@@ -826,6 +831,9 @@ int32_t mndTransPrepare(SMnode *pMnode, STrans *pTrans) {
mError
(
"trans:%d, failed to prepare since %s"
,
pTrans
->
id
,
terrstr
());
return
-
1
;
}
mndTransFreeObj
(
pMnode
->
pSdb
);
mDebug
(
"trans:%d, prepare finished"
,
pTrans
->
id
);
STrans
*
pNew
=
mndAcquireTrans
(
pMnode
,
pTrans
->
id
);
...
...
source/dnode/mnode/sdb/inc/sdb.h
浏览文件 @
04f94198
...
...
@@ -367,6 +367,7 @@ int64_t sdbGetTableVer(SSdb *pSdb, ESdbType type);
*/
void
sdbSetApplyInfo
(
SSdb
*
pSdb
,
int64_t
index
,
int64_t
term
,
int64_t
config
);
void
sdbGetCommitInfo
(
SSdb
*
pSdb
,
int64_t
*
index
,
int64_t
*
term
,
int64_t
*
config
);
void
sdbFreeRowsByType
(
SSdb
*
pSdb
,
ESdbType
type
);
SSdbRaw
*
sdbAllocRaw
(
ESdbType
type
,
int8_t
sver
,
int32_t
dataLen
);
void
sdbFreeRaw
(
SSdbRaw
*
pRaw
);
...
...
source/dnode/mnode/sdb/src/sdb.c
浏览文件 @
04f94198
...
...
@@ -65,6 +65,25 @@ SSdb *sdbInit(SSdbOpt *pOption) {
return
pSdb
;
}
void
sdbFreeRowsByType
(
SSdb
*
pSdb
,
ESdbType
type
)
{
SHashObj
*
hash
=
pSdb
->
hashObjs
[
type
];
if
(
hash
==
NULL
||
!
taosHashGetSize
(
hash
))
{
return
;
}
SSdbRow
**
ppRow
=
taosHashIterate
(
hash
,
NULL
);
while
(
ppRow
!=
NULL
)
{
SSdbRow
*
pRow
=
*
ppRow
;
if
(
pRow
==
NULL
)
{
ppRow
=
taosHashIterate
(
hash
,
ppRow
);
continue
;
}
sdbFreeRow
(
pSdb
,
pRow
,
false
);
ppRow
=
taosHashIterate
(
hash
,
ppRow
);
}
taosHashClear
(
hash
);
}
void
sdbCleanup
(
SSdb
*
pSdb
)
{
mDebug
(
"start to cleanup sdb"
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录