PostgreSQL启动过程中的那些事七:初始化共享内存和信号一:初始化shmemIndex和信号

本文详细介绍了PostgreSQL启动过程中如何初始化共享内存和信号。首先,通过函数调用流程图展示了初始化过程,接着计算了包括哈希表、数据缓冲、锁表等在内的共享内存大小。接着,通过PGSharedMemoryCreate()分配并初始化共享内存,同时记录关键信息到postmaster.pid文件。此外,文章还提到了spinlock锁的初始化和LWLock的分配。最后,详细阐述了如何使用InitShmemIndex()创建可扩展哈希表`ShmemIndex`作为共享内存的索引,用于管理内存片段。
摘要由CSDN通过智能技术生成
      pg现在要初始化另一块内存——共享内存shared memory(以后shared memory有时会简写成shmem),在这块内存里,pg存放数据、锁、各种backend进程等。

1先上个图,看一下函数调用过程梗概,中间略过部分细节


初始化共享内存方法调用流程图

 

2计算shared memory大小

        话说main()->…->PostmasterMain()->…->reset_shared(),在reset_shared()这个函数里,pg首先计算干xxx一堆事需要的内存大小size,然后分之。

        首先我们看看都计算了哪些内存,估算使用动态哈希表管理共享内存需要的内存;计算数据池及管理需要的内存(根据shared_buffer);计算锁表需要的共享内存;计算xlog、clog需要的共享内存;计算共享进程、子事务、并发控制、轻量级锁、backend进程、后台写等需要的共享内存等,这些共享内存统统累加到size。计算shared memory共享内存代码如下:

        size = 100000;

        size =add_size(size, hash_estimate_size(SHMEM_INDEX_SIZE,

                                                 sizeof(ShmemIndexEnt)));

        size =add_size(size, BufferShmemSize());

        size =add_size(size, LockShmemSize());

        size =add_size(size, ProcGlobalShmemSize());

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值