Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
38948569
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看板
提交
38948569
编写于
11月 28, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: alter db pages memory leak
上级
d266d7a2
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
27 addition
and
11 deletion
+27
-11
source/libs/tdb/src/db/tdbPCache.c
source/libs/tdb/src/db/tdbPCache.c
+27
-11
未找到文件。
source/libs/tdb/src/db/tdbPCache.c
浏览文件 @
38948569
...
...
@@ -349,15 +349,23 @@ static void tdbPCacheUnpinPage(SPCache *pCache, SPage *pPage) {
ASSERT
(
pPage
->
pLruNext
==
NULL
);
pPage
->
pLruPrev
=
&
(
pCache
->
lru
);
pPage
->
pLruNext
=
pCache
->
lru
.
pLruNext
;
pCache
->
lru
.
pLruNext
->
pLruPrev
=
pPage
;
pCache
->
lru
.
pLruNext
=
pPage
;
tdbDebug
(
"pCache:%p unpin page %p/%d/%d, nPages:%d"
,
pCache
,
pPage
,
TDB_PAGE_PGNO
(
pPage
),
pPage
->
id
,
pCache
->
nPages
);
if
(
pPage
->
id
<
pCache
->
nPages
)
{
pPage
->
pLruPrev
=
&
(
pCache
->
lru
);
pPage
->
pLruNext
=
pCache
->
lru
.
pLruNext
;
pCache
->
lru
.
pLruNext
->
pLruPrev
=
pPage
;
pCache
->
lru
.
pLruNext
=
pPage
;
pCache
->
nRecyclable
++
;
pCache
->
nRecyclable
++
;
// printf("unpin page %d pgno %d pPage %p\n", pPage->id, TDB_PAGE_PGNO(pPage), pPage);
tdbDebug
(
"pcache/unpin page %p/%d/%d"
,
pPage
,
TDB_PAGE_PGNO
(
pPage
),
pPage
->
id
);
// printf("unpin page %d pgno %d pPage %p\n", pPage->id, TDB_PAGE_PGNO(pPage), pPage);
tdbDebug
(
"pcache/unpin page %p/%d/%d"
,
pPage
,
TDB_PAGE_PGNO
(
pPage
),
pPage
->
id
);
}
else
{
tdbDebug
(
"pcache destroy page: %p/%d/%d"
,
pPage
,
TDB_PAGE_PGNO
(
pPage
),
pPage
->
id
);
tdbPCacheRemovePageFromHash
(
pCache
,
pPage
);
tdbPageDestroy
(
pPage
,
tdbDefaultFree
,
NULL
);
}
}
static
void
tdbPCacheRemovePageFromHash
(
SPCache
*
pCache
,
SPage
*
pPage
)
{
...
...
@@ -443,10 +451,18 @@ static int tdbPCacheOpenImpl(SPCache *pCache) {
}
static
int
tdbPCacheCloseImpl
(
SPCache
*
pCache
)
{
for
(
i32
iPage
=
0
;
iPage
<
pCache
->
nPages
;
iPage
++
)
{
if
(
pCache
->
aPage
[
iPage
])
{
tdbPageDestroy
(
pCache
->
aPage
[
iPage
],
tdbDefaultFree
,
NULL
);
pCache
->
aPage
[
iPage
]
=
NULL
;
// free free page
for
(
SPage
*
pPage
=
pCache
->
pFree
;
pPage
;)
{
SPage
*
pPageT
=
pPage
->
pFreeNext
;
tdbPageDestroy
(
pPage
,
tdbDefaultFree
,
NULL
);
pPage
=
pPageT
;
}
for
(
int32_t
iBucket
=
0
;
iBucket
<
pCache
->
nHash
;
iBucket
++
)
{
for
(
SPage
*
pPage
=
pCache
->
pgHash
[
iBucket
];
pPage
;)
{
SPage
*
pPageT
=
pPage
->
pHashNext
;
tdbPageDestroy
(
pPage
,
tdbDefaultFree
,
NULL
);
pPage
=
pPageT
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录