Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
12c6ea28
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看板
提交
12c6ea28
编写于
11月 03, 2021
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refact
上级
1f2f6a7b
变更
9
隐藏空白更改
内联
并排
Showing
9 changed file
with
54 addition
and
169 deletion
+54
-169
include/server/vnode/tsdb/impl/tsdbImpl.h
include/server/vnode/tsdb/impl/tsdbImpl.h
+7
-8
include/server/vnode/tsdb/tsdb.h
include/server/vnode/tsdb/tsdb.h
+10
-53
source/dnode/vnode/impl/src/vnodeCommit.c
source/dnode/vnode/impl/src/vnodeCommit.c
+2
-0
source/dnode/vnode/tsdb/inc/tsdbDef.h
source/dnode/vnode/tsdb/inc/tsdbDef.h
+15
-9
source/dnode/vnode/tsdb/inc/tsdbMemTable.h
source/dnode/vnode/tsdb/inc/tsdbMemTable.h
+0
-46
source/dnode/vnode/tsdb/inc/tsdbOptions.h
source/dnode/vnode/tsdb/inc/tsdbOptions.h
+3
-3
source/dnode/vnode/tsdb/src/tsdbMain.c
source/dnode/vnode/tsdb/src/tsdbMain.c
+16
-0
source/dnode/vnode/tsdb/src/tsdbMemTable.c
source/dnode/vnode/tsdb/src/tsdbMemTable.c
+0
-49
source/dnode/vnode/tsdb/src/tsdbOptions.c
source/dnode/vnode/tsdb/src/tsdbOptions.c
+1
-1
未找到文件。
source/dnode/vnode/tsdb/inc/tsdbWriteBatch
.h
→
include/server/vnode/tsdb/impl/tsdbImpl
.h
浏览文件 @
12c6ea28
...
...
@@ -13,22 +13,21 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _TD_TSDB_WRITE_BATCH_H_
#define _TD_TSDB_WRITE_BATCH_H_
#ifndef _TD_TSDB_IMPL_H_
#define _TD_TSDB_IMPL_H_
#include "os.h"
#ifdef __cplusplus
extern
"C"
{
#endif
typedef
struct
STsdbWriteBatch
STsdbWriteBatch
;
/* ------------------------- ------------------------- */
struct
STsdbWriteBatch
{
// TODO
struct
STsdbOptions
{
/* TODO */
};
#ifdef __cplusplus
}
#endif
#endif
/*_TD_TSDB_WRITE_BATCH_H_*/
\ No newline at end of file
#endif
/*_TD_TSDB_IMPL_H_*/
\ No newline at end of file
include/server/vnode/tsdb/tsdb.h
浏览文件 @
12c6ea28
...
...
@@ -16,67 +16,24 @@
#ifndef _TD_TSDB_H_
#define _TD_TSDB_H_
#include "os.h"
#include "taosmsg.h"
#include "impl/tsdbImpl.h"
#ifdef __cplusplus
extern
"C"
{
#endif
// Types exported
typedef
struct
STsdb
STsdb
;
typedef
struct
STsdbOptions
STsdbOptions
;
typedef
struct
STsdbSMAOptions
STsdbSMAOptions
;
// SMA stands for Small Materialized Aggregation
typedef
struct
STsdbReadOptions
STsdbReadOptions
;
typedef
struct
STsdbSnapshot
STsdbSnapshot
;
typedef
struct
STsdbQueryHandle
STsdbQueryHandle
;
// TYPES EXPOSED
typedef
struct
STsdb
STsdb
;
typedef
struct
STsdbOptions
STsdbOptions
;
// DB operations
int
tsdbCreate
(
const
char
*
path
);
int
tsdbDestroy
(
const
char
*
path
);
STsdb
*
tsdbOpen
(
const
STsdbOptions
*
options
);
// STsdb
STsdb
*
tsdbOpen
(
const
char
*
path
,
const
STsdbOptions
*
);
void
tsdbClose
(
STsdb
*
);
int
tsdbReset
(
STsdb
*
,
const
STsdbOptions
*
);
int
tsdbInsert
(
STsdb
*
,
SSubmitReq
*
,
SSubmitRsp
*
);
int
tsdbCommit
(
STsdb
*
);
int
tsdbCompact
(
STsdb
*
);
void
tsdbRemove
(
const
char
*
path
);
// Options
STsdbOptions
*
tsdbOptionsCreate
();
void
tsdbOptionsDestroy
(
STsdbOptions
*
);
void
tsdbOptionsSetId
(
STsdbOptions
*
,
int
id
);
void
tsdbOptionsSetHoursPerFile
(
STsdbOptions
*
,
int
hours
);
void
tsdbOptionsSetRetention
(
STsdbOptions
*
,
int
keep
,
int
keep1
,
int
keep2
);
void
tsdbOptionsSetMinAndMaxRows
(
STsdbOptions
*
,
int
minRows
,
int
maxRows
);
void
tsdbOptionsSetPrecision
(
STsdbOptions
*
,
int
);
void
tsdbOptionsSetCache
(
STsdbOptions
*
,
int
);
typedef
enum
{
TSDB_NO_UPDATE
=
0
,
TSDB_WHOLE_ROW_UPDATE
=
1
,
TSDB_PARTIAL_ROW_UPDATE
=
2
}
ETsdbUpdateType
;
void
tsdbOptionsSetUpdate
(
STsdbOptions
*
,
ETsdbUpdateType
);
void
tsdbOptionsSetSMA
(
STsdbOptions
*
,
STsdbSMAOptions
*
);
// STsdbSMAOptions
STsdbSMAOptions
*
tsdbSMAOptionsCreate
();
void
tsdbSMAOptionsDestroy
(
STsdbSMAOptions
*
);
// void tsdbSMAOptionsSetFuncs(STsdbSMAOptions *, SArray * /*Array of function to perform on each block*/);
// void tsdbSMAOptionsSetIntervals(STsdbSMAOptions *, SArray *);
// void tsdbSMAOptionsSetColTypes(STsdbSMAOptions *, SArray *);
// STsdbQueryHandle
STsdbQueryHandle
*
tsdbQueryHandleCreate
(
STsdb
*
,
STsdbReadOptions
*
);
void
tsdbQueryHandleDestroy
(
STsdbQueryHandle
*
);
void
tsdbResetQueryHandle
(
STsdbQueryHandle
*
,
STsdbReadOptions
*
);
bool
tsdbNextDataBlock
(
STsdbQueryHandle
*
);
// void tsdbGetDataBlockInfo(STsdbQueryHandle *, SDataBlockInfo *);
// void tsdbGetDataBlockStatisInfo(STsdbQueryHandle *, SDataStatis **);
// STsdbReadOptions
STsdbReadOptions
*
tsdbReadOptionsCreate
();
void
tsdbReadOptionsDestroy
(
STsdbReadOptions
*
);
void
tsdbReadOptionsSetSnapshot
(
STsdbReadOptions
*
,
STsdbSnapshot
*
);
// STsdbSnapshot
STsdbSnapshot
*
tsdbSnapshotCreate
(
STsdb
*
);
void
tsdbSnapshotDestroy
(
STsdbSnapshot
*
);
// STsdbOptions
int
tsdbOptionsInit
(
STsdbOptions
*
);
void
tsdbOptionsClear
(
STsdbOptions
*
);
#ifdef __cplusplus
}
...
...
source/dnode/vnode/impl/src/vnodeCommit.c
浏览文件 @
12c6ea28
...
...
@@ -19,6 +19,7 @@ static int vnodeStartCommit(SVnode *pVnode);
static
int
vnodeEndCommit
(
SVnode
*
pVnode
);
int
vnodeAsyncCommit
(
SVnode
*
pVnode
)
{
#if 0
if (vnodeStartCommit(pVnode) < 0) {
// TODO
}
...
...
@@ -39,6 +40,7 @@ int vnodeAsyncCommit(SVnode *pVnode) {
// TODO
}
#endif
return
0
;
}
...
...
source/dnode/vnode/tsdb/
src/tsdb.c
→
source/dnode/vnode/tsdb/
inc/tsdbDef.h
浏览文件 @
12c6ea28
...
...
@@ -13,17 +13,23 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _TD_TSDB_DEF_H_
#define _TD_TSDB_DEF_H_
#include "tsdb.h"
#include "tkv.h"
#include "tsdbMemTable.h"
#include "tsdbOptions.h"
#ifdef __cplusplus
extern
"C"
{
#endif
/* -------------- -------------- */
struct
STsdb
{
STkvDb
*
tsdb
;
// original time-series data
STkvDb
*
lrowdb
;
// last row cache
STkvDb
*
lastdb
;
// last cache
STkvDb
*
fivemindb
;
char
*
path
;
STsdbOptions
options
;
};
int
tsdbInsert
(
STsdb
*
tsdb
,
SSubmitReq
*
pReq
,
SSubmitRsp
*
pRsp
)
{
return
0
;
}
int
tsdbCommit
(
STsdb
*
pTsdb
)
{
return
0
;
}
\ No newline at end of file
#ifdef __cplusplus
}
#endif
#endif
/*_TD_TSDB_DEF_H_*/
\ No newline at end of file
source/dnode/vnode/tsdb/inc/tsdbMemTable.h
已删除
100644 → 0
浏览文件 @
1f2f6a7b
/*
* Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
*
* This program is free software: you can use, redistribute, and/or modify
* it under the terms of the GNU Affero General Public License, version 3
* or later ("AGPL"), as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _TD_TSDB_MEMTABLE_H_
#define _TD_TSDB_MEMTABLE_H_
#include "tdef.h"
#include "thash.h"
#include "amalloc.h"
#ifdef __cplusplus
extern
"C"
{
#endif
typedef
struct
STsdbMemTable
STsdbMemTable
;
STsdbMemTable
*
tsdbMemTableCreate
(
SMemAllocator
*
);
void
tsdbMemTableDestroy
(
STsdbMemTable
*
);
int
tsdbMemTableWriteBatch
(
STsdbMemTable
*
pTsdbMemTable
,
void
*
batch
);
/* --------------------- For compile and test only --------------------- */
struct
STsdbMemTable
{
TSKEY
minKey
;
TSKEY
maxKey
;
SHashObj
*
tData
;
// uid --> SSkipList
SMemAllocator
*
ma
;
T_REF_DECLARE
()
};
#ifdef __cplusplus
}
#endif
#endif
/*_TD_TSDB_MEMTABLE_H_*/
\ No newline at end of file
source/dnode/vnode/tsdb/inc/tsdb
Int
.h
→
source/dnode/vnode/tsdb/inc/tsdb
Options
.h
浏览文件 @
12c6ea28
...
...
@@ -13,8 +13,8 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _TD_TSDB_
INT
_H_
#define _TD_TSDB_
INT
_H_
#ifndef _TD_TSDB_
OPTIONS
_H_
#define _TD_TSDB_
OPTIONS
_H_
#ifdef __cplusplus
extern
"C"
{
...
...
@@ -24,4 +24,4 @@ extern "C" {
}
#endif
#endif
/*_TD_TSDB_INT_H_*/
\ No newline at end of file
#endif
/*_TD_TSDB_OPTIONS_H_*/
\ No newline at end of file
source/dnode/vnode/tsdb/src/tsdbMain.c
0 → 100644
浏览文件 @
12c6ea28
/*
* Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
*
* This program is free software: you can use, redistribute, and/or modify
* it under the terms of the GNU Affero General Public License, version 3
* or later ("AGPL"), as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "tsdbDef.h"
\ No newline at end of file
source/dnode/vnode/tsdb/src/tsdbMemTable.c
已删除
100644 → 0
浏览文件 @
1f2f6a7b
/*
* Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
*
* This program is free software: you can use, redistribute, and/or modify
* it under the terms of the GNU Affero General Public License, version 3
* or later ("AGPL"), as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "tsdbMemTable.h"
STsdbMemTable
*
tsdbMemTableCreate
(
SMemAllocator
*
ma
)
{
STsdbMemTable
*
pTsdbMemTable
=
NULL
;
pTsdbMemTable
=
(
STsdbMemTable
*
)
malloc
(
sizeof
(
*
pTsdbMemTable
));
if
(
pTsdbMemTable
==
NULL
)
{
return
NULL
;
}
// TODO
pTsdbMemTable
->
minKey
=
TSKEY_INITIAL_VAL
;
pTsdbMemTable
->
maxKey
=
TSKEY_INITIAL_VAL
;
pTsdbMemTable
->
ma
=
ma
;
pTsdbMemTable
->
tData
=
taosHashInit
(
1024
,
taosIntHash_64
,
true
/* TODO */
,
HASH_NO_LOCK
);
if
(
pTsdbMemTable
->
tData
==
NULL
)
{
// TODO
}
return
pTsdbMemTable
;
}
void
tsdbMemTableDestroy
(
STsdbMemTable
*
pTsdbMemTable
)
{
if
(
pTsdbMemTable
)
{
// TODO
free
(
pTsdbMemTable
);
}
}
int
tsdbMemTableWriteBatch
(
STsdbMemTable
*
pTsdbMemTable
,
void
*
batch
)
{
// TODO
return
0
;
}
\ No newline at end of file
source/dnode/vnode/tsdb/src/tsdb
SMA
.c
→
source/dnode/vnode/tsdb/src/tsdb
Options
.c
浏览文件 @
12c6ea28
...
...
@@ -11,4 +11,4 @@
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
*/
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录