Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
a086f83c
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看板
提交
a086f83c
编写于
2月 08, 2023
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: slow TDB page defragment
上级
e3ba07e0
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
46 addition
and
2 deletion
+46
-2
source/libs/tdb/src/db/tdbPage.c
source/libs/tdb/src/db/tdbPage.c
+46
-2
未找到文件。
source/libs/tdb/src/db/tdbPage.c
浏览文件 @
a086f83c
...
...
@@ -404,7 +404,52 @@ static int tdbPageFree(SPage *pPage, int idx, SCell *pCell, int szCell) {
return
0
;
}
typedef
struct
{
int32_t
iCell
;
int32_t
offset
;
}
SCellIdx
;
static
int32_t
tCellIdxCmprFn
(
const
void
*
p1
,
const
void
*
p2
)
{
if
(((
SCellIdx
*
)
p1
)
->
offset
<
((
SCellIdx
*
)
p2
)
->
offset
)
{
return
-
1
;
}
else
if
(((
SCellIdx
*
)
p1
)
->
offset
>
((
SCellIdx
*
)
p2
)
->
offset
)
{
return
1
;
}
else
{
return
0
;
}
}
static
int
tdbPageDefragment
(
SPage
*
pPage
)
{
#if 1
int32_t
nFree
=
TDB_PAGE_NFREE
(
pPage
);
int32_t
nCell
=
TDB_PAGE_NCELLS
(
pPage
);
SCellIdx
*
aCellIdx
=
(
SCellIdx
*
)
tdbOsMalloc
(
sizeof
(
SCellIdx
)
*
nCell
);
if
(
aCellIdx
==
NULL
)
return
-
1
;
for
(
int32_t
iCell
=
0
;
iCell
<
nCell
;
iCell
++
)
{
aCellIdx
[
iCell
].
iCell
=
iCell
;
aCellIdx
[
iCell
].
offset
=
TDB_PAGE_CELL_OFFSET_AT
(
pPage
,
iCell
);
}
taosSort
(
aCellIdx
,
nCell
,
sizeof
(
SCellIdx
),
tCellIdxCmprFn
);
SCell
*
pNextCell
=
(
u8
*
)
pPage
->
pPageFtr
;
for
(
int32_t
iCell
=
nCell
-
1
;
iCell
>=
0
;
iCell
--
)
{
SCell
*
pCell
=
TDB_PAGE_CELL_AT
(
pPage
,
aCellIdx
[
iCell
].
iCell
);
int32_t
szCell
=
pPage
->
xCellSize
(
pPage
,
pCell
,
0
,
NULL
,
NULL
);
ASSERT
(
pNextCell
-
szCell
>=
pCell
);
pNextCell
-=
szCell
;
if
(
pNextCell
>
pCell
)
{
memmove
(
pNextCell
,
pCell
,
szCell
);
TDB_PAGE_CELL_OFFSET_AT_SET
(
pPage
,
aCellIdx
[
iCell
].
iCell
,
pNextCell
-
pPage
->
pData
);
}
}
pPage
->
pFreeEnd
=
pNextCell
;
TDB_PAGE_CCELLS_SET
(
pPage
,
pPage
->
pFreeEnd
-
pPage
->
pData
);
TDB_PAGE_FCELL_SET
(
pPage
,
0
);
tdbOsFree
(
aCellIdx
);
ASSERT
(
pPage
->
pFreeEnd
-
pPage
->
pFreeStart
==
nFree
);
#else
int
nFree
;
int
nCells
;
SCell
*
pCell
;
...
...
@@ -457,10 +502,9 @@ static int tdbPageDefragment(SPage *pPage) {
TDB_PAGE_CELL_OFFSET_AT_SET
(
pPage
,
idx
,
pNextCell
-
pPage
->
pData
);
}
ASSERT
(
pPage
->
pFreeEnd
-
pPage
->
pFreeStart
==
nFree
);
TDB_PAGE_CCELLS_SET
(
pPage
,
pPage
->
pFreeEnd
-
pPage
->
pData
);
TDB_PAGE_FCELL_SET
(
pPage
,
0
);
#endif
return
0
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录