您的位置:首页 > 其它

深入理解缓冲区(五)

2011-09-28 08:34 267 查看

4.1 PostgreSQL数据缓冲区管理

4.1.1 PG缓冲区源码--文件介绍

位置:src/backend/storage/buffer/

文件名称

功能

buf_init.c

Buf初始化功能,初始化出三处内存空间,分别被BufferDescriptors、BufferBlocks、SharedBufHash、StrategyControl描述,注意这四个变量,他们表述了数据缓冲区的基本结构

buf_table.c

Buf管理的辅助文件,完成对SharedBufHash变量(此变量便于对缓冲区中的缓存块进行查找使用)表示的内存的管理操作(如初始化、查找、插入、删除等),主要有如下函数调用:

SharedBufHash

InitBufTable

BufTableHashCode

BufTableLookup

BufTableInsert

BufTableDelete

bufmgr.c

Buf的管理文件,完成对buf的管理操作,如buf的分配、回收等。主要的一些函数如ReadBuffer、ReadBufferExtended 、ReleaseBuffer、MarkBufferDirty等

freelist.c

Buf替换策略相关代码,完成对缓冲区替换策略的管理,主要有函数AddBufferToRing、FreeAccessStrategy、GetAccessStrategy、GetBufferFromRing、StrategyFreeBuffer、StrategyGetBuffer、StrategyInitialize、StrategyRejectBuffer、StrategyShmemSize、StrategySyncStart

localbuf.c

本地缓存管理。本地缓存,指的是对临时表的管理(PG有临时表的概念,create temp table,这些临时表被创建即进入内存,实则进入缓存)

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: