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());