深入理解缓冲区(五)

来源:互联网 发布:淘宝护肤品违禁词 编辑:程序博客网 时间:2024/05/29 03:48

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


原创粉丝点击