Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
e7ea5a0e
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看板
提交
e7ea5a0e
编写于
12月 07, 2021
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more
上级
40d12ec4
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
53 addition
and
34 deletion
+53
-34
source/dnode/vnode/meta/src/metaBDBImpl.c
source/dnode/vnode/meta/src/metaBDBImpl.c
+53
-34
未找到文件。
source/dnode/vnode/meta/src/metaBDBImpl.c
浏览文件 @
e7ea5a0e
...
...
@@ -33,29 +33,44 @@ struct SMetaDB {
DB_ENV
*
pEvn
;
};
#define P_ERROR(info, code) fprintf(stderr, info "reason: %s", db_strerror(code))
static
SMetaDB
*
metaNewDB
();
static
void
metaFreeDB
(
SMetaDB
*
pDB
);
static
int
metaCreateDBEnv
(
SMetaDB
*
pDB
,
const
char
*
path
);
static
void
metaDestroyDBEnv
(
SMetaDB
*
pDB
);
int
metaOpenDB
(
SMeta
*
pMeta
)
{
int
ret
;
SMetaDB
*
pDB
;
pMeta
->
pDB
=
metaNewDB
();
#if 0
// create the env
ret = db_env_create(&(pMeta->pDB->pEvn), 0);
if (ret != 0) {
// TODO: handle error
if
(
pMeta
->
pDB
==
NULL
)
{
return
-
1
;
}
ret = pMeta->pDB->pEvn->open(pMeta->pDB->pEvn, pMeta->path, DB_CREATE | DB_INIT_MPOOL, 0);
if (ret != 0) {
// TODO: handle error
pDB
=
pMeta
->
pDB
;
if
(
metaCreateDBEnv
(
pDB
,
pMeta
->
path
)
<
0
)
{
metaCloseDB
(
pMeta
);
return
-
1
;
}
// ret = db_create(&(pDB->pStbDB), pDB->pEvn, 0);
// if (ret != 0) {
// P_ERROR("failed to create META super table DB", ret);
// metaCloseDB(pMeta);
// return -1;
// }
// ret = pDB->pStbDB->open(pDB->pStbDB, NULL, "meta.db", NULL, DB_BTREE, DB_CREATE, 0);
// if (ret != 0) {
// P_ERROR("failed to create META super table DB", ret);
// metaCloseDB(pMeta);
// return -1;
// }
#if 0
ret = db_create(&(pMeta->pDB->pDB), pMeta->pDB->pEvn, 0);
if (ret != 0) {
// TODO: handle error
...
...
@@ -125,33 +140,11 @@ int metaOpenDB(SMeta *pMeta) {
}
void
metaCloseDB
(
SMeta
*
pMeta
)
{
metaFreeDB
(
pMeta
->
pDB
);
pMeta
->
pDB
=
NULL
;
#if 0
if
(
pMeta
->
pDB
)
{
if (pMeta->pDB->pIdx) {
pMeta->pDB->pIdx->close(pMeta->pDB->pIdx, 0);
pMeta->pDB->pIdx = NULL;
}
if (pMeta->pDB->pSchemaDB) {
pMeta->pDB->pSchemaDB->close(pMeta->pDB->pSchemaDB, 0);
pMeta->pDB->pSchemaDB = NULL;
}
if (pMeta->pDB->pDB) {
pMeta->pDB->pDB->close(pMeta->pDB->pDB, 0);
pMeta->pDB->pDB = NULL;
}
if (pMeta->pDB->pEvn) {
pMeta->pDB->pEvn->close(pMeta->pDB->pEvn, 0);
pMeta->pDB->pEvn = NULL;
}
free(pMeta->pDB);
metaDestroyDBEnv
(
pMeta
->
pDB
);
metaFreeDB
(
pMeta
->
pDB
);
pMeta
->
pDB
=
NULL
;
}
#endif
}
int
metaSaveTableToDB
(
SMeta
*
pMeta
,
STbCfg
*
pTbCfg
)
{
...
...
@@ -221,4 +214,30 @@ static void metaFreeDB(SMetaDB *pDB) {
free
(
pDB
);
}
}
static
int
metaCreateDBEnv
(
SMetaDB
*
pDB
,
const
char
*
path
)
{
int
ret
;
if
(
path
==
NULL
)
return
0
;
ret
=
db_env_create
(
&
(
pDB
->
pEvn
),
0
);
if
(
ret
!=
0
)
{
P_ERROR
(
"Failed to create META DB ENV"
,
ret
);
return
-
1
;
}
ret
=
pDB
->
pEvn
->
open
(
pDB
->
pEvn
,
path
,
DB_CREATE
|
DB_INIT_MPOOL
,
0
);
if
(
ret
!=
0
)
{
P_ERROR
(
"failed to open META DB ENV"
,
ret
);
return
-
1
;
}
return
0
;
}
static
void
metaDestroyDBEnv
(
SMetaDB
*
pDB
)
{
if
(
pDB
->
pEvn
)
{
pDB
->
pEvn
->
close
(
pDB
->
pEvn
,
0
);
}
}
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录