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,这些临时表被创建即进入内存,实则进入缓存) |