国产成人AV无码一二三区,少女1到100集,国产精品久久久久精品综合紧,巜公妇之诱感肉欲HD在线播放

文章 > PostgreSQL > PostgreSQL怎么提前缓存数据

PostgreSQL怎么提前缓存数据

头像

月亮邮递员

2020-03-28 13:52:153258浏览 · 0收藏 · 0评论

PostgreSQL怎么提前缓存数据

预热功能,使用pg_prewarm函数,方便的将数据缓存至内存中。

这个功能不是自带的,是存在在扩展包中,所以要使用前需要先添加扩展。

pg_prewarm(regclass, mode text default 'buffer', fork text default 'main', first_block int8 default null, last_block int8 default null) RETURNS int8

第一个参数是预热的relation。

第二个参数是要使用预热的方法

第三个参数是relation fork被预热

第四个参数是预热的第一个块号

第五个参数是预热的最后一个块号

返回值是prewarm块的数量。

预热方法有三种:

1、对操作系统发出异步prefetch请求

2、读取块的请求范围,但可能会较慢

3、缓冲区将请求的块范围(执行的查询)读入数据库缓冲区缓存中。

注意,使用这些方法中的任何一种,试图预热更多的块而不是缓存的操作系统——当使用预取或读取时,或使用PostgreSQL在使用缓冲器时可能会导致较低编号的块被释放,因为较高编号的块被读入。预热数据也没有对缓存驱逐的特殊?;?,因此其他系统活动可能会在读取后不久将新的预热块驱逐出去;反之,预热也可能从高速缓存中驱逐其他数据。由于这些原因,预热通常在启动时最有用,当缓存大部分为空时。

操作,实验环境:

CentOS 7 + PG 10.1

创建extension

mytest=# create extension pg_prewarm ;
CREATE EXTENSION

在这个实验中,我们需要借助pg_buffercache 来查看内存中的变化。

mytest=# create extension pg_buffercache ;
CREATE EXTENSION

我们重启一下pg

service postgresql-10 restart

查看内存信息

mytest=# select count(*) from pg_buffercache where relfilenode = (select relfilenode from pg_class where relname = 'test01');
count
-------
0
(1 row)
mytest=# select pg_prewarm('test01','buffer','main') ;
pg_prewarm
------------
2041
(1 row)
mytest=# select count(*) from pg_buffercache where relfilenode = (select relfilenode from pg_class where relname = 'test01');
count
-------
2041
(1 row)

说明表已经被缓存到内存中。

推荐:postgresql教程

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

《无能的丈夫》完整版| 冲动的惩罚未删减| 《疯狂72小时》韩剧| 福艳都市韵母王雪琴| 黑科网 今日黑科独家爆料| 屁股翘起来跪在床上有好处吗| 《寂寞的背叛》免费播放| 年轻的母亲在线观看| 麻花MV在线看免费观看电视剧| 《性爽2》电影| 七星彩开奖号码最新结果| 征服双收岳女两2| 《浴室吃奶2》无删减| 皇上被群臣扒开腿狂C| 免费观看已满十八岁电视剧在线播....| 黑色蕾丝女装| 明星记忆修改系统| 日本大片又大又好看的PPT| 女生胸前两颗大大的包是什么| (NP、高H、纯肉、真空)| 如何正确拔萝卜| 性做爰全过程免费看| 少女潘金莲| 上课装睡B被同学扣了一节课| 女主被兄弟三人轮流欺负的小说 | 《吃你吃上瘾》| 妈妈与儿子高清免费版电视剧| 韩剧公媳之恋免费观看全集| 空姐4免费高清完整版观看| 快拨出天我是你母亲歌词监控| 家公给我治疗5中字| 《淫毛》在线观看免费| 火鸟出击| 快拨出天我是你母亲歌词监控 | 36D胸围是多大| 公交车被上高湖了还能坐吗小说| 我和两个继拇交换做爰| 《卻望1973》娃娃脸| 出门忘穿胸罩乳头凸起怎么办| 《交换做爰》在线观看| 快乐8