首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将表保留在缓冲区中的Postgres pg_prewarm在删除表后返回0

将表保留在缓冲区中的Postgres pg_prewarm在删除表后返回0
EN

Stack Overflow用户
提问于 2021-01-25 19:05:35
回答 1查看 177关注 0票数 0

我按照本教程中概述的步骤在PostgreSQL中使用pg_prewarm扩展预热缓冲区缓存:

https://ismailyenigul.medium.com/pg-prewarm-extention-to-pre-warming-the-buffer-cache-in-postgresql-7e033b9a386d

第一次运行它时,我得到的结果是1

代码语言:javascript
运行
复制
mydb=> SELECT pg_prewarm('useraccount');
 pg_prewarm 
------------
          1

在那之后,我不得不删除该表并重新创建它。从那时起,当我运行相同的命令时,我总是得到0作为结果。我不确定这是意料之中的,还是我错过了什么?

代码语言:javascript
运行
复制
mydb=> SELECT pg_prewarm('useraccount');
 pg_prewarm 
------------
          0
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-01-25 19:54:59

contrib/pg_prewarm/pg_prewarm.c中的函数注释为:

代码语言:javascript
运行
复制
 * [...] The
 * return value is the number of blocks successfully prewarmed.

所以第一次,表中有一个块。删除并重新创建该表后,该表为空,因此缓存了0个块。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65883517

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档