pg的内存除了AllocSet/MemoryContext外,另一个主要部分就是共享内存(shared memory)。这一节讨论共享内存(简写shmem)的分配。
pg在reset_shared()这个函数里,计算数据缓冲、xlog、clog、共享进程、子事务、并发控制、轻量级锁、backend进程等需要的共享内存,调用shmget()函数在堆上分配,用PGShmemHeader *类型的ShmemSegHdr变量的index成员指向调用hash_create()创建的共享内存索引——可扩展哈希表索引"ShmemIndex";totalSize成员中记录分配的shmem大小。
有了共享内存和共享内存索引,再加上一个共享内存锁(关于此锁及pg中的其它锁,是一个需要很多字才能讨论清楚的点,以后专门讨论),就可以分配共享内存了。
分配共享内存时,先把要分配内存的结构做对齐处理,然后回去共享内存锁,接着判断要分配的内存大小,大于8k的需要做块对齐,从共享内存的空闲共享内存偏移量处分配所需大小内存,判断所分配内存是否超过了共享内存的末尾地址,如果超过,释放锁,报错"out of sharedmemory"