Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
b25e55cf
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
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看板
提交
b25e55cf
编写于
6月 14, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more work
上级
62f9403e
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
82 addition
and
121 deletion
+82
-121
source/dnode/vnode/src/inc/tsdb.h
source/dnode/vnode/src/inc/tsdb.h
+34
-51
source/dnode/vnode/src/tsdb/tsdbCommit.c
source/dnode/vnode/src/tsdb/tsdbCommit.c
+30
-70
source/dnode/vnode/src/tsdb/tsdbUtil.c
source/dnode/vnode/src/tsdb/tsdbUtil.c
+18
-0
未找到文件。
source/dnode/vnode/src/inc/tsdb.h
浏览文件 @
b25e55cf
...
...
@@ -48,6 +48,7 @@ typedef struct SOffset SOffset;
typedef
struct
SMapData
SMapData
;
typedef
struct
SColData
SColData
;
typedef
struct
SColDataBlock
SColDataBlock
;
typedef
struct
SBlockSMA
SBlockSMA
;
// tsdbMemTable ==============================================================================================
...
...
@@ -86,9 +87,24 @@ int32_t tsdbFSEnd(STsdbFS *pFS, int8_t rollback);
// SDataFWriter
typedef
struct
SDataFWriter
SDataFWriter
;
int32_t
tsdbDataFWriterOpen
(
SDataFWriter
*
pWriter
,
STsdb
*
pTsdb
,
SDFileSet
*
pSet
);
int32_t
tsdbDataFWriterClose
(
SDataFWriter
*
pWriter
);
int32_t
tsdbWriteBlockIdx
(
SDataFWriter
*
pWriter
,
SMapData
*
pMapData
,
uint8_t
**
ppBuf
);
int32_t
tsdbWriteBlock
(
SDataFWriter
*
pWriter
,
SMapData
*
pMapData
,
uint8_t
**
ppBuf
,
int64_t
*
rOffset
,
int64_t
*
rSize
);
int32_t
tsdbWriteBlockData
(
SDataFWriter
*
pWriter
,
SColDataBlock
*
pBlockData
,
uint8_t
**
ppBuf
,
int64_t
*
rOffset
,
int64_t
*
rSize
);
int32_t
tsdbWriteBlockSMA
(
SDataFWriter
*
pWriter
,
SBlockSMA
*
pBlockSMA
,
int64_t
*
rOffset
,
int64_t
*
rSize
);
// SDataFReader
typedef
struct
SDataFReader
SDataFReader
;
int32_t
tsdbDataFReaderOpen
(
SDataFReader
*
pReader
,
STsdb
*
pTsdb
,
SDFileSet
*
pSet
);
int32_t
tsdbDataFReaderClose
(
SDataFReader
*
pReader
);
int32_t
tsdbReadBlockIdx
(
SDataFReader
*
pReader
,
SMapData
*
pMapData
,
uint8_t
**
ppBuf
);
int32_t
tsdbReadBlock
(
SDataFReader
*
pReader
,
SBlockIdx
*
pBlockIdx
,
SMapData
*
pMapData
,
uint8_t
**
ppBuf
);
int32_t
tsdbReadBlockData
(
SDataFReader
*
pReader
,
SBlock
*
pBlock
,
SColDataBlock
*
pBlockData
,
uint8_t
**
ppBuf
);
int32_t
tsdbReadBlockSMA
(
SDataFReader
*
pReader
,
SBlockSMA
*
pBlkSMA
);
// SDelFWriter
typedef
struct
SDelFWriter
SDelFWriter
;
...
...
@@ -125,29 +141,9 @@ typedef struct SAggrBlkCol SAggrBlkCol;
typedef
struct
SBlockData
SBlockData
;
typedef
struct
SReadH
SReadH
;
typedef
struct
SDFileSetReader
SDFileSetReader
;
typedef
struct
SDFileSetWriter
SDFileSetWriter
;
// SDFileSetWriter
// int32_t tsdbDFileSetWriterOpen(SDFileSetWriter *pWriter, STsdb *pTsdb, SDFileSet *pSet);
// int32_t tsdbDFileSetWriterClose(SDFileSetWriter *pWriter, int8_t sync);
// int32_t tsdbWriteBlockData(SDFileSetWriter *pWriter, SDataCols *pDataCols, SBlock *pBlock);
// int32_t tsdbWriteSBlockInfo(SDFileSetWriter *pWriter, SBlockInfo *pBlockInfo, SBlockIdx *pBlockIdx);
// int32_t tsdbWriteSBlockIdx(SDFileSetWriter *pWriter, SBlockIdx *pBlockIdx);
// SDFileSetReader
// int32_t tsdbDFileSetReaderOpen(SDFileSetReader *pReader, STsdb *pTsdb, SDFileSet *pSet);
// int32_t tsdbDFileSetReaderClose(SDFileSetReader *pReader);
// int32_t tsdbLoadSBlockIdx(SDFileSetReader *pReader, SArray *pArray);
// int32_t tsdbLoadSBlockInfo(SDFileSetReader *pReader, SBlockIdx *pBlockIdx, SBlockInfo *pBlockInfo);
// int32_t tsdbLoadSBlockStatis(SDFileSetReader *pReader, SBlock *pBlock, SBlockStatis *pBlockStatis);
// SDelFWriter
// SDelFReader
// tsdbUtil.c ==============================================================================================
int32_t
tsdbKeyFid
(
TSKEY
key
,
int32_t
minutes
,
int8_t
precision
);
void
tsdbFidKeyRange
(
int32_t
fid
,
int32_t
minutes
,
int8_t
precision
,
TSKEY
*
minKey
,
TSKEY
*
maxKey
);
int32_t
tsdbRealloc
(
uint8_t
**
ppBuf
,
int64_t
size
);
void
tsdbFree
(
uint8_t
*
pBuf
);
...
...
@@ -284,7 +280,7 @@ struct TSDBROW {
};
};
struct
SBlockIdx
Item
{
struct
SBlockIdx
{
int64_t
suid
;
int64_t
uid
;
TSDBKEY
minKey
;
...
...
@@ -295,15 +291,6 @@ struct SBlockIdxItem {
int64_t
size
;
};
struct
SBlockIdx
{
int64_t
suid
;
int64_t
uid
;
uint32_t
delimiter
;
SOffset
offset
;
uint32_t
nData
;
uint8_t
*
pData
;
};
typedef
enum
{
TSDB_SBLK_VER_0
=
0
,
TSDB_SBLK_VER_MAX
,
...
...
@@ -365,26 +352,6 @@ struct SBlockData {
typedef
void
SAggrBlkData
;
// SBlockCol cols[];
static
FORCE_INLINE
int
TSDB_KEY_FID
(
TSKEY
key
,
int32_t
minutes
,
int8_t
precision
)
{
if
(
key
<
0
)
{
return
(
int
)((
key
+
1
)
/
tsTickPerMin
[
precision
]
/
minutes
-
1
);
}
else
{
return
(
int
)((
key
/
tsTickPerMin
[
precision
]
/
minutes
));
}
}
static
FORCE_INLINE
int
tsdbGetFidLevel
(
int
fid
,
SRtn
*
pRtn
)
{
if
(
fid
>=
pRtn
->
maxFid
)
{
return
0
;
}
else
if
(
fid
>=
pRtn
->
midFid
)
{
return
1
;
}
else
if
(
fid
>=
pRtn
->
minFid
)
{
return
2
;
}
else
{
return
-
1
;
}
}
// ================== TSDB global config
extern
bool
tsdbForceKeepFile
;
...
...
@@ -457,6 +424,7 @@ struct SMapData {
uint8_t
*
pOfst
;
uint32_t
nData
;
uint8_t
*
pData
;
uint8_t
*
pBuf
;
};
struct
SColData
{
...
...
@@ -474,6 +442,21 @@ struct SColDataBlock {
SColData
*
aColData
;
};
typedef
struct
{
int16_t
colId
;
int16_t
maxIndex
;
int16_t
minIndex
;
int16_t
numOfNull
;
int64_t
sum
;
int64_t
max
;
int64_t
min
;
}
SColSMA
;
struct
SBlockSMA
{
int32_t
nCol
;
SColSMA
*
aColSMA
;
};
#ifdef __cplusplus
}
#endif
...
...
source/dnode/vnode/src/tsdb/tsdbCommit.c
浏览文件 @
b25e55cf
...
...
@@ -15,9 +15,7 @@
#include "tsdb.h"
typedef
struct
SCommitter
SCommitter
;
struct
SCommitter
{
typedef
struct
{
STsdb
*
pTsdb
;
uint8_t
*
pBuf1
;
uint8_t
*
pBuf2
;
...
...
@@ -29,15 +27,15 @@ struct SCommitter {
int8_t
precision
;
int32_t
minRow
;
int32_t
maxRow
;
TSKEY
nextCommitKey
;
// commit file data
TSKEY
nextKey
;
int32_t
commitFid
;
TSKEY
minKey
;
TSKEY
maxKey
;
SDFileSetReader
*
pReader
;
SMapData
oBlockIdx
;
// SMapData<SBlockIdx>, read from reader
SDFileSetWriter
*
pWriter
;
SMapData
oBlockIdx
;
SMapData
nBlockIdx
;
SMapData
nBlockIdx
;
// SMapData<SBlockIdx>, build by committer
// commit table data
STbDataIter
iter
;
STbDataIter
*
pIter
;
...
...
@@ -57,7 +55,7 @@ struct SCommitter {
SDelData
delDataNew
;
SDelIdxItem
delIdxItem
;
/* commit cache */
};
}
SCommitter
;
static
int32_t
tsdbStartCommit
(
STsdb
*
pTsdb
,
SCommitter
*
pCommitter
);
static
int32_t
tsdbCommitData
(
SCommitter
*
pCommitter
);
...
...
@@ -81,8 +79,15 @@ _err:
int32_t
tsdbCommit
(
STsdb
*
pTsdb
)
{
int32_t
code
=
0
;
SCommitter
commith
=
{
0
};
int
fid
;
SCommitter
commith
;
SMemTable
*
pMemTable
=
pTsdb
->
mem
;
// check
if
(
pMemTable
->
nRow
==
0
&&
pMemTable
->
nDel
==
0
)
{
// TODO
pTsdb
->
mem
=
NULL
;
tsdbMemTableDestroy
(
pMemTable
);
goto
_exit
;
}
// start commit
code
=
tsdbStartCommit
(
pTsdb
,
&
commith
);
...
...
@@ -112,9 +117,11 @@ int32_t tsdbCommit(STsdb *pTsdb) {
goto
_err
;
}
_exit:
return
code
;
_err:
tsdbEndCommit
(
&
commith
,
code
);
tsdbError
(
"vgId:%d, failed to commit since %s"
,
TD_VID
(
pTsdb
->
pVnode
),
tstrerror
(
code
));
return
code
;
}
...
...
@@ -122,6 +129,7 @@ _err:
static
int32_t
tsdbStartCommit
(
STsdb
*
pTsdb
,
SCommitter
*
pCommitter
)
{
int32_t
code
=
0
;
memset
(
pCommitter
,
0
,
sizeof
(
*
pCommitter
));
ASSERT
(
pTsdb
->
mem
&&
pTsdb
->
imem
==
NULL
);
// lock();
pTsdb
->
imem
=
pTsdb
->
mem
;
...
...
@@ -133,36 +141,24 @@ static int32_t tsdbStartCommit(STsdb *pTsdb, SCommitter *pCommitter) {
return
code
;
}
static
int32_t
tsdbCommitDataStart
(
SCommitter
*
pCommitter
);
static
int32_t
tsdbCommitDataImpl
(
SCommitter
*
pCommitter
);
static
int32_t
tsdbCommitDataEnd
(
SCommitter
*
pCommitter
);
static
int32_t
tsdbCommitData
(
SCommitter
*
pCommitter
)
{
int32_t
code
=
0
;
STsdb
*
pTsdb
=
pCommitter
->
pTsdb
;
SMemTable
*
pMemTable
=
pTsdb
->
imem
;
//
no data, just return
//
check
if
(
pMemTable
->
nRow
==
0
)
{
goto
_exit
;
}
// start
code
=
tsdbCommitDataStart
(
pCommitter
);
if
(
code
)
{
goto
_err
;
}
// commit
code
=
tsdbCommitDataImpl
(
pCommitter
);
if
(
code
)
{
goto
_err
;
}
// end
code
=
tsdbCommitDataEnd
(
pCommitter
);
if
(
code
)
{
goto
_err
;
// loop
pCommitter
->
nextKey
=
pMemTable
->
minKey
.
ts
;
while
(
pCommitter
->
nextKey
<
TSKEY_MAX
)
{
pCommitter
->
commitFid
=
tsdbKeyFid
(
pCommitter
->
nextKey
,
pCommitter
->
minutes
,
pCommitter
->
precision
);
tsdbFidKeyRange
(
pCommitter
->
commitFid
,
pCommitter
->
minutes
,
pCommitter
->
precision
,
&
pCommitter
->
minKey
,
&
pCommitter
->
maxKey
);
code
=
tsdbCommitFileData
(
pCommitter
);
if
(
code
)
goto
_err
;
}
_exit:
...
...
@@ -359,40 +355,6 @@ static int32_t tsdbEndCommit(SCommitter *pCommitter, int32_t eno) {
return
code
;
}
static
int32_t
tsdbCommitDataStart
(
SCommitter
*
pCommitter
)
{
int32_t
code
=
0
;
STsdb
*
pTsdb
=
pCommitter
->
pTsdb
;
SMemTable
*
pMemTable
=
pTsdb
->
imem
;
pCommitter
->
nextCommitKey
=
pMemTable
->
minKey
.
ts
;
return
code
;
}
static
int32_t
tsdbCommitFileData
(
SCommitter
*
pCommitter
);
static
int32_t
tsdbCommitDataImpl
(
SCommitter
*
pCommitter
)
{
int32_t
code
=
0
;
while
(
pCommitter
->
nextCommitKey
<
TSKEY_MAX
)
{
pCommitter
->
commitFid
=
tsdbKeyFid
(
pCommitter
->
nextCommitKey
,
pCommitter
->
minutes
,
pCommitter
->
precision
);
code
=
tsdbCommitFileData
(
pCommitter
);
if
(
code
)
goto
_err
;
}
_exit:
return
code
;
_err:
return
code
;
}
static
int32_t
tsdbCommitDataEnd
(
SCommitter
*
pCommitter
)
{
int32_t
code
=
0
;
// TODO
return
code
;
}
static
int32_t
tsdbCommitFileDataStart
(
SCommitter
*
pCommitter
);
static
int32_t
tsdbCommitFileDataImpl
(
SCommitter
*
pCommitter
);
static
int32_t
tsdbCommitFileDataEnd
(
SCommitter
*
pCommitter
);
...
...
@@ -430,10 +392,11 @@ static int32_t tsdbCommitFileDataStart(SCommitter *pCommitter) {
SDFileSet
*
pRSet
=
NULL
;
// TODO
SDFileSet
*
pWSet
=
NULL
;
// TODO
// memory
tMapDataReset
(
&
pCommitter
->
oBlockIdx
);
tMapDataReset
(
&
pCommitter
->
nBlockIdx
);
// load old
pCommitter
->
oBlockIdx
.
nItem
=
0
;
pCommitter
->
oBlockIdx
.
flag
=
0
;
pCommitter
->
oBlockIdx
.
nData
=
0
;
if
(
pRSet
)
{
code
=
tsdbDFileSetReaderOpen
(
&
pCommitter
->
pReader
,
pTsdb
,
pRSet
);
if
(
code
)
goto
_err
;
...
...
@@ -443,9 +406,6 @@ static int32_t tsdbCommitFileDataStart(SCommitter *pCommitter) {
}
// create new
pCommitter
->
nBlockIdx
.
nItem
=
0
;
pCommitter
->
nBlockIdx
.
flag
=
0
;
pCommitter
->
nBlockIdx
.
nData
=
0
;
code
=
tsdbDFileSetWriterOpen
(
&
pCommitter
->
pWriter
,
pTsdb
,
pWSet
);
if
(
code
)
goto
_err
;
...
...
source/dnode/vnode/src/tsdb/tsdbUtil.c
浏览文件 @
b25e55cf
...
...
@@ -140,6 +140,7 @@ void tMapDataReset(SMapData *pMapData) {
void
tMapDataClear
(
SMapData
*
pMapData
)
{
tsdbFree
(
pMapData
->
pOfst
);
tsdbFree
(
pMapData
->
pData
);
tsdbFree
(
pMapData
->
pBuf
);
}
int32_t
tMapDataPutItem
(
SMapData
*
pMapData
,
void
*
pItem
,
int32_t
(
*
tPutItemFn
)(
uint8_t
*
,
void
*
))
{
...
...
@@ -741,6 +742,23 @@ int32_t tsdbKeyFid(TSKEY key, int32_t minutes, int8_t precision) {
}
}
void
tsdbFidKeyRange
(
int32_t
fid
,
int32_t
minutes
,
int8_t
precision
,
TSKEY
*
minKey
,
TSKEY
*
maxKey
)
{
*
minKey
=
fid
*
minutes
*
tsTickPerMin
[
precision
];
*
maxKey
=
*
minKey
+
minutes
*
tsTickPerMin
[
precision
]
-
1
;
}
// int tsdFidLevel(int fid, TSKEY now, minute) {
// if (fid >= pRtn->maxFid) {
// return 0;
// } else if (fid >= pRtn->midFid) {
// return 1;
// } else if (fid >= pRtn->minFid) {
// return 2;
// } else {
// return -1;
// }
// }
// TSDBROW ======================================================
void
tsdbRowGetColVal
(
TSDBROW
*
pRow
,
STSchema
*
pTSchema
,
int32_t
iCol
,
SColVal
*
pColVal
)
{
// TODO
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录