Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
6af7d4cf
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1187
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看板
提交
6af7d4cf
编写于
6月 11, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more work
上级
b4252f8b
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
163 addition
and
22 deletion
+163
-22
source/dnode/vnode/src/inc/tsdb.h
source/dnode/vnode/src/inc/tsdb.h
+6
-2
source/dnode/vnode/src/tsdb/tsdbCommit.c
source/dnode/vnode/src/tsdb/tsdbCommit.c
+92
-17
source/dnode/vnode/src/tsdb/tsdbReaderWriter.c
source/dnode/vnode/src/tsdb/tsdbReaderWriter.c
+40
-3
source/dnode/vnode/src/tsdb/tsdbUtil.c
source/dnode/vnode/src/tsdb/tsdbUtil.c
+25
-0
未找到文件。
source/dnode/vnode/src/inc/tsdb.h
浏览文件 @
6af7d4cf
...
...
@@ -90,7 +90,7 @@ typedef struct SDelFWriter SDelFWriter;
int32_t
tsdbDelFWriterOpen
(
SDelFWriter
**
ppWriter
,
SDelFile
*
pFile
,
STsdb
*
pTsdb
);
int32_t
tsdbDelFWriterClose
(
SDelFWriter
*
pWriter
,
int8_t
sync
);
int32_t
tsdbWriteDelData
(
SDelFWriter
*
pWriter
,
SDelData
*
pDelData
,
uint8_t
**
ppBuf
,
SDelIdxItem
*
pItem
);
int32_t
tsdbWriteDelData
(
SDelFWriter
*
pWriter
,
SDelData
*
pDelData
,
uint8_t
**
ppBuf
);
int32_t
tsdbWriteDelIdx
(
SDelFWriter
*
pWriter
,
SDelIdx
*
pDelIdx
,
uint8_t
**
ppBuf
);
int32_t
tsdbUpdateDelFileHdr
(
SDelFWriter
*
pWriter
,
uint8_t
**
ppBuf
);
...
...
@@ -99,7 +99,7 @@ typedef struct SDelFReader SDelFReader;
int32_t
tsdbDelFReaderOpen
(
SDelFReader
**
ppReader
,
SDelFile
*
pFile
,
STsdb
*
pTsdb
,
uint8_t
**
ppBuf
);
int32_t
tsdbDelFReaderClose
(
SDelFReader
*
pReader
);
int32_t
tsdbReadDelData
(
SDelFReader
*
pReader
,
SDelData
*
pDelData
,
uint8_t
**
ppBuf
);
int32_t
tsdbReadDelData
(
SDelFReader
*
pReader
,
SDel
IdxItem
*
pItem
,
SDel
Data
*
pDelData
,
uint8_t
**
ppBuf
);
int32_t
tsdbReadDelIdx
(
SDelFReader
*
pReader
,
SDelIdx
*
pDelIdx
,
uint8_t
**
ppBuf
);
// SCacheFWriter
...
...
@@ -151,10 +151,14 @@ int32_t tsdbKeyCmprFn(const void *p1, const void *p2);
// SDelIdx
int32_t
tDelIdxGetSize
(
SDelIdx
*
pDelIdx
);
int32_t
tDelIdxGetItem
(
SDelIdx
*
pDelIdx
,
int32_t
idx
,
SDelIdxItem
*
pItem
);
int32_t
tDelIdxPutItem
(
SDelIdx
*
pDelIdx
,
SDelIdxItem
*
pItem
);
int32_t
tPutDelIdx
(
uint8_t
*
p
,
SDelIdx
*
pDelIdx
);
int32_t
tGetDelIdx
(
uint8_t
*
p
,
SDelIdx
*
pDelIdx
);
// SDelData
int32_t
tDelDataGetSize
(
SDelData
*
pDelData
);
int32_t
tDelDataGetItem
(
SDelData
*
pDelData
,
int32_t
idx
,
SDelDataItem
*
pItem
);
int32_t
tDelDataPutItem
(
SDelData
*
pDelData
,
SDelDataItem
*
pItem
);
int32_t
tPutDelData
(
uint8_t
*
p
,
SDelData
*
pDelData
);
int32_t
tGetDelData
(
uint8_t
*
p
,
SDelData
*
pDelData
);
...
...
source/dnode/vnode/src/tsdb/tsdbCommit.c
浏览文件 @
6af7d4cf
...
...
@@ -46,6 +46,7 @@ struct SCommitter {
SDelIdx
nDelIdx
;
SDelData
oDelData
;
SDelData
nDelData
;
SDelIdxItem
delIdxItem
;
/* commit cache */
};
...
...
@@ -203,6 +204,8 @@ _err:
return
code
;
}
static
int32_t
tsdbCommitTableDel
(
SCommitter
*
pCommitter
);
static
int32_t
tsdbCommitDelImpl
(
SCommitter
*
pCommitter
)
{
int32_t
code
=
0
;
STsdb
*
pTsdb
=
pCommitter
->
pTsdb
;
...
...
@@ -215,32 +218,28 @@ static int32_t tsdbCommitDelImpl(SCommitter *pCommitter) {
SDelIdx
*
pDelIdx
=
NULL
;
SDelIdx
delIdx
;
if
(
iTbData
<
nTbData
)
{
pTbData
=
(
STbData
*
)
taosArrayGetP
(
pMemTable
->
aTbData
,
iTbData
);
}
if
(
iDelIdx
<
nDelIdx
)
{
// tIMapGet();
pDelIdx
=
&
delIdx
;
}
//
if (iTbData < nTbData) {
//
pTbData = (STbData *)taosArrayGetP(pMemTable->aTbData, iTbData);
//
}
//
if (iDelIdx < nDelIdx) {
//
// tIMapGet();
//
pDelIdx = &delIdx;
//
}
while
(
iTbData
<
nTbData
||
iDelIdx
<
nDelIdx
)
{
if
(
pTbData
&&
pDelIdx
)
{
}
else
{
}
// start
// 1. load table del if exist
// impl
while
(
1
)
{
// do merge
}
// end
// tsdbWriteDelData
code
=
tsdbCommitTableDel
(
pCommitter
);
if
(
code
)
goto
_err
;
}
return
code
;
_err:
tsdbError
(
"vgId:%d commit del impl failed since %s"
,
TD_VID
(
pTsdb
->
pVnode
),
tstrerror
(
code
));
return
code
;
}
static
int32_t
tsdbCommitDelEnd
(
SCommitter
*
pCommitter
)
{
...
...
@@ -540,6 +539,82 @@ static int32_t tsdbCommitTableDataEnd(SCommitter *pCommitter) {
return
code
;
}
static
int32_t
tsdbCommitTableDelStart
(
SCommitter
*
pCommitter
)
{
int32_t
code
=
0
;
// load old
pCommitter
->
oDelData
=
(
SDelData
){
0
};
if
(
0
)
{
code
=
tsdbReadDelData
(
pCommitter
->
pDelFReader
,
NULL
/*TODO*/
,
&
pCommitter
->
oDelData
,
&
pCommitter
->
pBuf4
);
if
(
code
)
goto
_err
;
}
// prepare new
pCommitter
->
nDelData
=
(
SDelData
){
0
};
return
code
;
_err:
tsdbError
(
"vgId:%d commit table del start failed since %s"
,
TD_VID
(
pCommitter
->
pTsdb
->
pVnode
),
tstrerror
(
code
));
return
code
;
}
static
int32_t
tsdbCommitTableDelImpl
(
SCommitter
*
pCommitter
)
{
int32_t
code
=
0
;
SDelOp
*
pDelOp
=
NULL
;
for
(;
pDelOp
;
pDelOp
=
pDelOp
->
pNext
)
{
SDelDataItem
item
=
{.
version
=
pDelOp
->
version
,
.
sKey
=
pDelOp
->
sKey
,
.
eKey
=
pDelOp
->
eKey
};
code
=
tDelDataPutItem
(
&
pCommitter
->
nDelData
,
&
item
);
if
(
code
)
goto
_err
;
}
return
code
;
_err:
return
code
;
}
static
int32_t
tsdbCommitTableDelEnd
(
SCommitter
*
pCommitter
)
{
int32_t
code
=
0
;
// write table del data
code
=
tsdbWriteDelData
(
pCommitter
->
pDelFWriter
,
&
pCommitter
->
nDelData
,
NULL
);
if
(
code
)
goto
_err
;
// add SDelIdxItem
code
=
tDelIdxPutItem
(
&
pCommitter
->
nDelIdx
,
&
pCommitter
->
delIdxItem
);
if
(
code
)
goto
_err
;
return
code
;
_err:
tsdbError
(
"vgId:%d commit table del end failed since %s"
,
TD_VID
(
pCommitter
->
pTsdb
->
pVnode
),
tstrerror
(
code
));
return
code
;
}
static
int32_t
tsdbCommitTableDel
(
SCommitter
*
pCommitter
)
{
int32_t
code
=
0
;
// start
code
=
tsdbCommitTableDelStart
(
pCommitter
);
if
(
code
)
goto
_err
;
// impl
code
=
tsdbCommitTableDelImpl
(
pCommitter
);
if
(
code
)
goto
_err
;
// end
code
=
tsdbCommitTableDelEnd
(
pCommitter
);
if
(
code
)
goto
_err
;
return
code
;
_err:
return
code
;
}
// // ===================================== OLD ======================================
#if 0
struct SCommitIter {
...
...
source/dnode/vnode/src/tsdb/tsdbReaderWriter.c
浏览文件 @
6af7d4cf
...
...
@@ -136,13 +136,15 @@ _err:
return
code
;
}
int32_t
tsdbWriteDelDta
(
SDelFWriter
*
pWriter
,
SDelData
*
pDelData
,
uint8_t
**
ppBuf
)
{
int32_t
tsdbWriteDelD
a
ta
(
SDelFWriter
*
pWriter
,
SDelData
*
pDelData
,
uint8_t
**
ppBuf
)
{
int32_t
code
=
0
;
uint8_t
*
pBuf
=
NULL
;
int64_t
size
;
int64_t
n
;
// prepare
pDelData
->
delimiter
=
TSDB_FILE_DLMT
;
// todo
// alloc
if
(
!
ppBuf
)
ppBuf
=
&
pBuf
;
...
...
@@ -334,9 +336,44 @@ _exit:
return
code
;
}
int32_t
tsdbReadDelData
(
SDelFReader
*
pReader
,
SDelData
*
pDelData
,
uint8_t
**
ppBuf
)
{
int32_t
tsdbReadDelData
(
SDelFReader
*
pReader
,
SDel
IdxItem
*
pItem
,
SDel
Data
*
pDelData
,
uint8_t
**
ppBuf
)
{
int32_t
code
=
0
;
// TODO
int64_t
n
;
// seek
if
(
taosLSeekFile
(
pReader
->
pReadH
,
pItem
->
offset
,
SEEK_SET
)
<
0
)
{
code
=
TAOS_SYSTEM_ERROR
(
errno
);
goto
_err
;
}
// alloc
code
=
tsdbRealloc
(
ppBuf
,
pItem
->
size
);
if
(
code
)
goto
_err
;
// read
n
=
taosReadFile
(
pReader
->
pReadH
,
*
ppBuf
,
pItem
->
size
);
if
(
n
<
0
)
{
code
=
TAOS_SYSTEM_ERROR
(
errno
);
goto
_err
;
}
// check
if
(
!
taosCheckChecksumWhole
(
*
ppBuf
,
pItem
->
size
))
{
code
=
TSDB_CODE_FILE_CORRUPTED
;
goto
_err
;
}
// decode
n
=
tGetDelData
(
*
ppBuf
,
pDelData
);
ASSERT
(
n
+
sizeof
(
TSCKSUM
)
==
pItem
->
size
);
ASSERT
(
pDelData
->
delimiter
==
TSDB_FILE_DLMT
);
ASSERT
(
pDelData
->
suid
=
pItem
->
suid
);
ASSERT
(
pDelData
->
uid
=
pItem
->
uid
);
return
code
;
_err:
tsdbError
(
"vgId:%d read del data failed since %s"
,
TD_VID
(
pReader
->
pTsdb
->
pVnode
),
tstrerror
(
code
));
return
code
;
}
...
...
source/dnode/vnode/src/tsdb/tsdbUtil.c
浏览文件 @
6af7d4cf
...
...
@@ -101,6 +101,12 @@ int32_t tDelIdxGetItem(SDelIdx *pDelIdx, int32_t idx, SDelIdxItem *pItem) {
return
code
;
}
int32_t
tDelIdxPutItem
(
SDelIdx
*
pDelIdx
,
SDelIdxItem
*
pItem
)
{
int32_t
code
=
0
;
// TODO
return
code
;
}
int32_t
tPutDelIdx
(
uint8_t
*
p
,
SDelIdx
*
pDelIdx
)
{
int32_t
n
=
0
;
...
...
@@ -123,6 +129,25 @@ int32_t tGetDelIdx(uint8_t *p, SDelIdx *pDelIdx) {
return
n
;
}
// SDelData ======================================================
int32_t
tDelDataGetSize
(
SDelData
*
pDelData
)
{
int32_t
code
=
0
;
// TODO
return
code
;
}
int32_t
tDelDataGetItem
(
SDelData
*
pDelData
,
int32_t
idx
,
SDelDataItem
*
pItem
)
{
int32_t
code
=
0
;
// TODO
return
code
;
}
int32_t
tDelDataPutItem
(
SDelData
*
pDelData
,
SDelDataItem
*
pItem
)
{
int32_t
code
=
0
;
// TODO
return
code
;
}
int32_t
tPutDelData
(
uint8_t
*
p
,
SDelData
*
pDelData
)
{
int32_t
n
=
0
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录