Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
712bc9a0
T
TDengine
项目概览
taosdata
/
TDengine
大约 2 年 前同步成功
通知
1192
Star
22018
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看板
提交
712bc9a0
编写于
8月 26, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more code
上级
daf5d423
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
145 addition
and
36 deletion
+145
-36
source/dnode/vnode/src/tsdb/tsdbCommit.c
source/dnode/vnode/src/tsdb/tsdbCommit.c
+145
-36
未找到文件。
source/dnode/vnode/src/tsdb/tsdbCommit.c
浏览文件 @
712bc9a0
...
@@ -656,7 +656,8 @@ _err:
...
@@ -656,7 +656,8 @@ _err:
}
}
static
int32_t
tsdbCommitTableMemData
(
SCommitter
*
pCommitter
,
STbDataIter
*
pIter
,
TSDBKEY
toKey
)
{
static
int32_t
tsdbCommitTableMemData
(
SCommitter
*
pCommitter
,
STbDataIter
*
pIter
,
TSDBKEY
toKey
)
{
int32_t
code
=
0
;
int32_t
code
=
0
;
#if 0
STbData *pTbData = pIter->pTbData;
STbData *pTbData = pIter->pTbData;
SBlockData *pBlockData = &pCommitter->dWriter.bData;
SBlockData *pBlockData = &pCommitter->dWriter.bData;
...
@@ -699,6 +700,7 @@ static int32_t tsdbCommitTableMemData(SCommitter *pCommitter, STbDataIter *pIter
...
@@ -699,6 +700,7 @@ static int32_t tsdbCommitTableMemData(SCommitter *pCommitter, STbDataIter *pIter
_err:
_err:
tsdbError("vgId:%d, tsdb commit table mem data failed since %s", TD_VID(pCommitter->pTsdb->pVnode), tstrerror(code));
tsdbError("vgId:%d, tsdb commit table mem data failed since %s", TD_VID(pCommitter->pTsdb->pVnode), tstrerror(code));
#endif
return
code
;
return
code
;
}
}
...
@@ -1346,12 +1348,11 @@ static int32_t tRowInfoCmprFn(const void *p1, const void *p2) {
...
@@ -1346,12 +1348,11 @@ static int32_t tRowInfoCmprFn(const void *p1, const void *p2) {
return
tsdbRowCmprFn
(
&
pInfo1
->
row
,
&
pInfo2
->
row
);
return
tsdbRowCmprFn
(
&
pInfo1
->
row
,
&
pInfo2
->
row
);
}
}
static
SRowInfo
*
tsdbGetCommitRow
(
SCommitter
*
pCommitter
)
{
static
FORCE_INLINE
SRowInfo
*
tsdbGetCommitRow
(
SCommitter
*
pCommitter
)
{
// TODO
return
(
pCommitter
->
pIter
)
?
&
pCommitter
->
pIter
->
r
:
NULL
;
return
NULL
;
}
}
static
int32_t
tsdbNextCommitRow
(
SCommitter
*
pCommitter
,
SRowInfo
**
ppInfo
)
{
static
int32_t
tsdbNextCommitRow
(
SCommitter
*
pCommitter
)
{
int32_t
code
=
0
;
int32_t
code
=
0
;
if
(
pCommitter
->
pIter
)
{
if
(
pCommitter
->
pIter
)
{
...
@@ -1429,25 +1430,139 @@ static int32_t tsdbNextCommitRow(SCommitter *pCommitter, SRowInfo **ppInfo) {
...
@@ -1429,25 +1430,139 @@ static int32_t tsdbNextCommitRow(SCommitter *pCommitter, SRowInfo **ppInfo) {
}
}
}
}
if
(
pCommitter
->
pIter
)
{
*
ppInfo
=
&
pCommitter
->
pIter
->
r
;
}
else
{
*
ppInfo
=
NULL
;
}
_exit:
_exit:
return
code
;
return
code
;
}
}
static
int32_t
tsdbCommitAheadBlock
(
SCommitter
*
pCommitter
,
SBlock
*
pBlock
)
{
static
int32_t
tsdbCommitAheadBlock
(
SCommitter
*
pCommitter
,
SBlock
*
pBlock
)
{
int32_t
code
=
0
;
int32_t
code
=
0
;
// TODO
SBlockData
*
pBlockData
=
&
pCommitter
->
dWriter
.
bData
;
SRowInfo
*
pRowInfo
=
tsdbGetCommitRow
(
pCommitter
);
TABLEID
id
=
{.
suid
=
pRowInfo
->
suid
,
.
uid
=
pRowInfo
->
uid
};
tBlockDataClear
(
pBlockData
);
while
(
pRowInfo
)
{
ASSERT
(
pRowInfo
->
row
.
type
==
0
);
code
=
tsdbCommitterUpdateRowSchema
(
pCommitter
,
id
.
suid
,
id
.
uid
,
TSDBROW_SVERSION
(
&
pRowInfo
->
row
));
if
(
code
)
goto
_err
;
code
=
tBlockDataAppendRow
(
pBlockData
,
&
pRowInfo
->
row
,
pCommitter
->
skmRow
.
pTSchema
,
id
.
uid
);
if
(
code
)
goto
_err
;
code
=
tsdbNextCommitRow
(
pCommitter
);
if
(
code
)
goto
_err
;
pRowInfo
=
tsdbGetCommitRow
(
pCommitter
);
if
(
pRowInfo
)
{
if
(
pRowInfo
->
suid
!=
id
.
suid
||
pRowInfo
->
uid
!=
id
.
uid
)
{
pRowInfo
=
NULL
;
}
else
{
TSDBKEY
tKey
=
TSDBROW_KEY
(
&
pRowInfo
->
row
);
if
(
tsdbKeyCmprFn
(
&
tKey
,
&
pBlock
->
minKey
)
>=
0
)
pRowInfo
=
NULL
;
}
}
if
(
pBlockData
->
nRow
>=
pCommitter
->
maxRow
*
4
/
5
)
{
code
=
tsdbCommitDataBlock
(
pCommitter
,
NULL
);
if
(
code
)
goto
_err
;
}
}
if
(
pBlockData
->
nRow
)
{
code
=
tsdbCommitDataBlock
(
pCommitter
,
NULL
);
if
(
code
)
goto
_err
;
}
return
code
;
_err:
tsdbError
(
"vgId:%d, tsdb commit ahead block failed since %s"
,
TD_VID
(
pCommitter
->
pTsdb
->
pVnode
),
tstrerror
(
code
));
return
code
;
return
code
;
}
}
static
int32_t
tsdbCommitMergeBlock
(
SCommitter
*
pCommitter
,
SBlock
*
pBlock
)
{
static
int32_t
tsdbCommitMergeBlock
(
SCommitter
*
pCommitter
,
SBlock
*
pBlock
)
{
int32_t
code
=
0
;
int32_t
code
=
0
;
// TODO
SRowInfo
*
pRowInfo
=
tsdbGetCommitRow
(
pCommitter
);
TABLEID
id
=
{.
suid
=
pRowInfo
->
suid
,
.
uid
=
pRowInfo
->
uid
};
SBlockData
*
pBDataR
=
&
pCommitter
->
dReader
.
bData
;
SBlockData
*
pBDataW
=
&
pCommitter
->
dWriter
.
bData
;
code
=
tsdbReadDataBlock
(
pCommitter
->
dReader
.
pReader
,
pBlock
,
pBDataR
);
if
(
code
)
goto
_err
;
tBlockDataClear
(
pBDataW
);
int32_t
iRow
=
0
;
TSDBROW
row
=
tsdbRowFromBlockData
(
pBDataR
,
0
);
TSDBROW
*
pRow
=
&
row
;
while
(
pRow
&&
pRowInfo
)
{
int32_t
c
=
tsdbRowCmprFn
(
pRow
,
&
pRowInfo
->
row
);
if
(
c
<
0
)
{
code
=
tBlockDataAppendRow
(
pBDataW
,
pRow
,
NULL
,
id
.
uid
);
if
(
code
)
goto
_err
;
iRow
++
;
if
(
iRow
<
pBDataR
->
nRow
)
{
row
=
tsdbRowFromBlockData
(
pBDataR
,
iRow
);
}
else
{
pRow
=
NULL
;
}
}
else
if
(
c
>
0
)
{
ASSERT
(
pRowInfo
->
row
.
type
==
0
);
code
=
tsdbCommitterUpdateRowSchema
(
pCommitter
,
id
.
suid
,
id
.
uid
,
TSDBROW_SVERSION
(
&
pRowInfo
->
row
));
if
(
code
)
goto
_err
;
code
=
tBlockDataAppendRow
(
pBDataW
,
&
pRowInfo
->
row
,
pCommitter
->
skmRow
.
pTSchema
,
id
.
uid
);
if
(
code
)
goto
_err
;
code
=
tsdbNextCommitRow
(
pCommitter
);
if
(
code
)
goto
_err
;
pRowInfo
=
tsdbGetCommitRow
(
pCommitter
);
if
(
pRowInfo
)
{
if
(
pRowInfo
->
suid
!=
id
.
suid
||
pRowInfo
->
uid
!=
id
.
uid
)
{
pRowInfo
=
NULL
;
}
else
{
TSDBKEY
tKey
=
TSDBROW_KEY
(
&
pRowInfo
->
row
);
if
(
tsdbKeyCmprFn
(
&
tKey
,
&
pBlock
->
maxKey
)
>
0
)
pRowInfo
=
NULL
;
}
}
}
else
{
ASSERT
(
0
);
}
if
(
pBDataW
->
nRow
>=
pCommitter
->
maxRow
*
4
/
5
)
{
code
=
tsdbCommitDataBlock
(
pCommitter
,
NULL
);
if
(
code
)
goto
_err
;
}
}
while
(
pRow
)
{
code
=
tBlockDataAppendRow
(
pBDataW
,
pRow
,
NULL
,
id
.
uid
);
if
(
code
)
goto
_err
;
iRow
++
;
if
(
iRow
<
pBDataR
->
nRow
)
{
row
=
tsdbRowFromBlockData
(
pBDataR
,
iRow
);
}
else
{
pRow
=
NULL
;
}
if
(
pBDataW
->
nRow
>=
pCommitter
->
maxRow
*
4
/
5
)
{
code
=
tsdbCommitDataBlock
(
pCommitter
,
NULL
);
if
(
code
)
goto
_err
;
}
}
if
(
pBDataW
->
nRow
)
{
code
=
tsdbCommitDataBlock
(
pCommitter
,
NULL
);
if
(
code
)
goto
_err
;
}
return
code
;
_err:
tsdbError
(
"vgId:%d, tsdb commit merge block failed since %s"
,
TD_VID
(
pCommitter
->
pTsdb
->
pVnode
),
tstrerror
(
code
));
return
code
;
return
code
;
}
}
...
@@ -1533,12 +1648,8 @@ static int32_t tsdbCommitFileDataImpl(SCommitter *pCommitter) {
...
@@ -1533,12 +1648,8 @@ static int32_t tsdbCommitFileDataImpl(SCommitter *pCommitter) {
SRowInfo
*
pRowInfo
=
NULL
;
SRowInfo
*
pRowInfo
=
NULL
;
TABLEID
id
=
{
0
};
TABLEID
id
=
{
0
};
while
(
true
)
{
while
(
true
)
{
code
=
tsdbNextCommitRow
(
pCommitter
,
&
pRowInfo
);
pRowInfo
=
tsdbGetCommitRow
(
pCommitter
);
if
(
code
)
goto
_err
;
if
(
pRowInfo
==
NULL
)
{
if
(
pRowInfo
==
NULL
)
{
/* end current table data commit (todo) */
/* end remain table data commit*/
/* end remain table data commit*/
code
=
tsdbMoveCommitData
(
pCommitter
,
(
TABLEID
){.
suid
=
INT64_MAX
,
.
uid
=
INT64_MAX
});
code
=
tsdbMoveCommitData
(
pCommitter
,
(
TABLEID
){.
suid
=
INT64_MAX
,
.
uid
=
INT64_MAX
});
if
(
code
)
goto
_err
;
if
(
code
)
goto
_err
;
...
@@ -1551,23 +1662,21 @@ static int32_t tsdbCommitFileDataImpl(SCommitter *pCommitter) {
...
@@ -1551,23 +1662,21 @@ static int32_t tsdbCommitFileDataImpl(SCommitter *pCommitter) {
break
;
break
;
}
}
if
(
id
.
suid
!=
pRowInfo
->
suid
||
id
.
uid
!=
pRowInfo
->
uid
)
{
ASSERT
(
pRowInfo
->
suid
!=
id
.
suid
||
pRowInfo
->
uid
!=
id
.
uid
);
/* end current table data commit (todo) */
/* start new table data commit */
/* start new table data commit */
id
.
suid
=
pRowInfo
->
suid
;
id
.
suid
=
pRowInfo
->
suid
;
id
.
uid
=
pRowInfo
->
uid
;
id
.
uid
=
pRowInfo
->
uid
;
// reader
// reader
code
=
tsdbMoveCommitData
(
pCommitter
,
id
);
code
=
tsdbMoveCommitData
(
pCommitter
,
id
);
if
(
code
)
goto
_err
;
if
(
code
)
goto
_err
;
// writer
// writer
tMapDataReset
(
&
pCommitter
->
dWriter
.
mBlock
);
tMapDataReset
(
&
pCommitter
->
dWriter
.
mBlock
);
// other
// other
code
=
tsdbCommitterUpdateTableSchema
(
pCommitter
,
id
.
suid
,
id
.
uid
);
code
=
tsdbCommitterUpdateTableSchema
(
pCommitter
,
id
.
suid
,
id
.
uid
);
if
(
code
)
goto
_err
;
if
(
code
)
goto
_err
;
code
=
tBlockDataInit
(
&
pCommitter
->
dWriter
.
bData
,
id
.
suid
,
id
.
uid
,
pCommitter
->
skmRow
.
pTSchema
);
code
=
tBlockDataInit
(
&
pCommitter
->
dWriter
.
bData
,
id
.
suid
,
id
.
uid
,
pCommitter
->
skmRow
.
pTSchema
);
if
(
code
)
goto
_err
;
if
(
code
)
goto
_err
;
}
/* merge with data in .data file */
/* merge with data in .data file */
code
=
tsdbMergeTableData
(
pCommitter
,
id
);
code
=
tsdbMergeTableData
(
pCommitter
,
id
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录