PG体系结构之内存结构

0    1172    5

Tags:

👉 本文共约5889个字,系统预计阅读时间或需23分钟。

内存结构

PostgreSQL的内存体系结构可以分为两大类:

  • Local memory area 本地内存区域——由每个后端进程分配供自己使用。
  • Shared memory area 共享内存区域——由PostgreSQL服务器的所有进程使用。

共享内存(Shared memory area)

共享内存区域由PostgreSQL服务器在启动时分配。这个区域也被划分为几个固定大小的子区域。

PostgreSQL启动后,会生成一块共享内存,用于做数据块的缓冲区,以便提高读写性能。WAL日志缓冲区和Clog缓冲区也存在共享内存中,除此之外还有全局信息比如进程、锁、全局统计等信息也保存在共享内存中。
其中最重要的组成部分是Shared Buffer和WAL Buffer。

√ Shared Buffer Pool
PostgreSQL将表和索引中的页面从持久存储加载到这里,并直接操作它们。Shared Buffer的目的是减少磁盘IO。为了达到这个目的,必须满足以下规则∶

  • 当需要快速访问非常大的缓存时(10G、100G等)

  • 如果有很多用户同时使用缓存,需要将内容尽量缩小

  • 频繁访问的磁盘块必须长期放在缓存中

    对应的设置参数为:shared_buffers

√ WAL Buffer
WAL Buffer是用来临时存储数据库变化的缓存区域。存储在WAL Buffer中的内容会根据提前定义好的时间点参数要求写入到磁盘的WAL文件中。为了保证数据不因服务器故障而丢失,PostgreSQL支持WAL机制。WAL data(也称XLOG records)是PostgreSQL中的事务日志;WAL buffer是WAL数据写入持久存储之前的缓冲区域。
在备份和恢复的场景下,WAL Buffer和WAL文件是极其重要的。

√ CommitLOG

提交日志(CLOG)保存所有事务(如in_progress,committed,aborted)的状态,用于并发控制(CC)机制。

本地内存(Local memory area )

每个backend进程分配一个本地内存区域用于查询处理;每个区域又分为几个子区域,子区域的大小可以是固定的,也可以是可变的。非全局存储的数据都存在本地内存中。下表列出了主要的子区域。

表 Local memory area

子区域描述
work_memExecutor使用此区域按顺序和不同的操作对元组进行排序,并使用merge-join和hash-join操作来连接表。内部排序操作和Hash表在使用临时操作文件之前使用的存储缓冲区。
maintenance_work_mem在某些维护操作,例如VACUUM(收集表和索引的统计信息,整理表和索引)、CREATE INDEX、ALTER TABLE ADD FOREIGN Key、Reindex等中都会使用这个区域。
temp_buffersExecutor使用此区域存储临时表。用于访问临时表的缓冲区。

除了上面提到的本地内存区域和共享内存区域,PostgreSQL还分配了如下几个区域:

用于各种访问控制机制的子区域,例如,信号量、轻量级锁、共享锁和排他锁等

用于各种后台进程的子区域,如checkpointer和autovacuum。

用于事务处理的子区域,比如保存点和两阶段提交。

等等。

本人提供Oracle(OCP、OCM)、MySQL(OCP)、PostgreSQL(PGCA、PGCE、PGCM)等数据库的培训和考证业务,私聊QQ646634621或微信dbaup66,谢谢!
AiDBA后续精彩内容已被站长无情隐藏,请输入验证码解锁本文!
验证码:
获取验证码: 请先关注本站微信公众号,然后回复“验证码”,获取验证码。在微信里搜索“AiDBA”或者“dbaup6”或者微信扫描右侧二维码都可以关注本站微信公众号。

标签:

Avatar photo

小麦苗

学习或考证,均可联系麦老师,请加微信db_bao或QQ646634621

您可能还喜欢...

发表回复