Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
3a427340
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看板
提交
3a427340
编写于
9月 15, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more code
上级
4a281e32
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
36 addition
and
16 deletion
+36
-16
source/dnode/vnode/src/inc/tsdb.h
source/dnode/vnode/src/inc/tsdb.h
+15
-6
source/dnode/vnode/src/tsdb/tsdbMemTable.c
source/dnode/vnode/src/tsdb/tsdbMemTable.c
+17
-6
source/dnode/vnode/src/tsdb/tsdbRead.c
source/dnode/vnode/src/tsdb/tsdbRead.c
+4
-4
未找到文件。
source/dnode/vnode/src/inc/tsdb.h
浏览文件 @
3a427340
...
...
@@ -65,6 +65,7 @@ typedef struct SSmaInfo SSmaInfo;
typedef
struct
SBlockCol
SBlockCol
;
typedef
struct
SVersionRange
SVersionRange
;
typedef
struct
SLDataIter
SLDataIter
;
typedef
struct
SQueryNode
SQueryNode
;
#define TSDB_FILE_DLMT ((uint32_t)0xF00AFA0F)
#define TSDB_MAX_SUBBLOCKS 8
...
...
@@ -206,8 +207,8 @@ int32_t tsdbDecmprColData(uint8_t *pIn, SBlockCol *pBlockCol, int8_t cmprAlg, in
int32_t
tsdbMemTableCreate
(
STsdb
*
pTsdb
,
SMemTable
**
ppMemTable
);
void
tsdbMemTableDestroy
(
SMemTable
*
pMemTable
);
STbData
*
tsdbGetTbDataFromMemTable
(
SMemTable
*
pMemTable
,
tb_uid_t
suid
,
tb_uid_t
uid
);
int32_t
tsdbRefMemTable
(
SMemTable
*
pMemTable
,
STsdbReader
*
pReader
);
int32_t
tsdbUnrefMemTable
(
SMemTable
*
pMemTable
,
S
TsdbReader
*
pReader
);
int32_t
tsdbRefMemTable
(
SMemTable
*
pMemTable
,
void
*
pQueryHandle
,
SQueryNode
**
ppNode
);
int32_t
tsdbUnrefMemTable
(
SMemTable
*
pMemTable
,
S
QueryNode
*
pNode
);
SArray
*
tsdbMemTableGetTbDataArray
(
SMemTable
*
pMemTable
);
// STbDataIter
int32_t
tsdbTbDataIterCreate
(
STbData
*
pTbData
,
TSDBKEY
*
pFrom
,
int8_t
backward
,
STbDataIter
**
ppIter
);
...
...
@@ -365,6 +366,12 @@ struct STbData {
STbData
*
next
;
};
struct
SQueryNode
{
SQueryNode
*
pNext
;
SQueryNode
**
ppNext
;
void
*
pQueryHandle
;
};
struct
SMemTable
{
SRWLatch
latch
;
STsdb
*
pTsdb
;
...
...
@@ -381,7 +388,7 @@ struct SMemTable {
int32_t
nBucket
;
STbData
**
aBucket
;
};
S
TsdbReader
*
pReader
List
;
S
QueryNode
*
q
List
;
};
struct
TSDBROW
{
...
...
@@ -592,9 +599,11 @@ struct SDelFWriter {
};
struct
STsdbReadSnap
{
SMemTable
*
pMem
;
SMemTable
*
pIMem
;
STsdbFS
fs
;
SMemTable
*
pMem
;
SQueryNode
*
pNode
;
SMemTable
*
pIMem
;
SQueryNode
*
pINode
;
STsdbFS
fs
;
};
struct
SDataFWriter
{
...
...
source/dnode/vnode/src/tsdb/tsdbMemTable.c
浏览文件 @
3a427340
...
...
@@ -629,24 +629,35 @@ _err:
int32_t
tsdbGetNRowsInTbData
(
STbData
*
pTbData
)
{
return
pTbData
->
sl
.
size
;
}
int32_t
tsdbRefMemTable
(
SMemTable
*
pMemTable
,
STsdbReader
*
pReader
)
{
int32_t
tsdbRefMemTable
(
SMemTable
*
pMemTable
,
void
*
pQueryHandle
,
SQueryNode
**
ppNode
)
{
int32_t
code
=
0
;
int32_t
nRef
=
atomic_fetch_add_32
(
&
pMemTable
->
nRef
,
1
);
ASSERT
(
nRef
>
0
);
// register handle (todo)
if
(
pReader
)
{
// register handle
*
ppNode
=
taosMemoryMalloc
(
sizeof
(
SQueryNode
));
if
(
*
ppNode
==
NULL
)
{
code
=
TSDB_CODE_OUT_OF_MEMORY
;
goto
_exit
;
}
(
*
ppNode
)
->
pQueryHandle
=
pQueryHandle
;
(
*
ppNode
)
->
pNext
=
pMemTable
->
qList
;
(
*
ppNode
)
->
ppNext
=
&
pMemTable
->
qList
;
pMemTable
->
qList
=
*
ppNode
;
_exit:
return
code
;
}
int32_t
tsdbUnrefMemTable
(
SMemTable
*
pMemTable
,
S
TsdbReader
*
pReader
)
{
int32_t
tsdbUnrefMemTable
(
SMemTable
*
pMemTable
,
S
QueryNode
*
pNode
)
{
int32_t
code
=
0
;
// unregister handle (todo)
if
(
pReader
)
{
// unregister handle
if
(
pNode
)
{
pNode
->
pNext
->
ppNext
=
pNode
->
ppNext
;
*
pNode
->
ppNext
=
pNode
->
pNext
;
taosMemoryFree
(
pNode
);
}
int32_t
nRef
=
atomic_sub_fetch_32
(
&
pMemTable
->
nRef
,
1
);
...
...
source/dnode/vnode/src/tsdb/tsdbRead.c
浏览文件 @
3a427340
...
...
@@ -3879,12 +3879,12 @@ int32_t tsdbTakeReadSnap(STsdbReader* pReader, STsdbReadSnap** ppSnap) {
// take snapshot
if
(
pTsdb
->
mem
&&
(
pRange
->
minVer
<=
pTsdb
->
mem
->
maxVer
&&
pRange
->
maxVer
>=
pTsdb
->
mem
->
minVer
))
{
tsdbRefMemTable
(
pTsdb
->
mem
,
pReader
);
tsdbRefMemTable
(
pTsdb
->
mem
,
pReader
,
&
(
*
ppSnap
)
->
pNode
);
(
*
ppSnap
)
->
pMem
=
pTsdb
->
mem
;
}
if
(
pTsdb
->
imem
&&
(
pRange
->
minVer
<=
pTsdb
->
imem
->
maxVer
&&
pRange
->
maxVer
>=
pTsdb
->
imem
->
minVer
))
{
tsdbRefMemTable
(
pTsdb
->
imem
,
pReader
);
tsdbRefMemTable
(
pTsdb
->
imem
,
pReader
,
&
(
*
ppSnap
)
->
pINode
);
(
*
ppSnap
)
->
pIMem
=
pTsdb
->
imem
;
}
...
...
@@ -3912,11 +3912,11 @@ void tsdbUntakeReadSnap(STsdbReader* pReader, STsdbReadSnap* pSnap) {
if
(
pSnap
)
{
if
(
pSnap
->
pMem
)
{
tsdbUnrefMemTable
(
pSnap
->
pMem
,
p
Reader
);
tsdbUnrefMemTable
(
pSnap
->
pMem
,
p
Snap
->
pNode
);
}
if
(
pSnap
->
pIMem
)
{
tsdbUnrefMemTable
(
pSnap
->
pIMem
,
p
Reader
);
tsdbUnrefMemTable
(
pSnap
->
pIMem
,
p
Snap
->
pINode
);
}
tsdbFSUnref
(
pTsdb
,
&
pSnap
->
fs
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录