更新时间:2024-04-25 GMT+08:00
分享

Global SysCache参数

enable_global_syscache

参数说明:控制是否使用全局系统缓存功能。该参数属于POSTMASTER类型参数,请参考表1中对应设置方法进行设置。

取值范围:布尔型

  • on表示开启全局系统缓存功能。
  • off表示不开启全局系统缓存功能。

默认值:on

推荐结合线程池参数使用。打开该参数后,如果需要访问备机,建议设置备机wal_level级别为hot_standby以上。

global_syscache_threshold

参数说明:全局系统缓存内存最大占用大小。

该参数属于SIGHUP类型参数,请参考表1中对应设置方法进行设置。

需要打开enable_global_syscache参数。

取值范围:整型,16384~1073741824,单位为kB。

默认值:

163840(196核CPU/1536G内存,128核CPU/1024G内存,104核CPU/1024G内存,96核CPU/1024G内存,96核CPU/768G内存,80核CPU/640G内存,64核CPU/512G内存,60核CPU/480G内存,32核CPU/256G内存,16核CPU/128G内存,8核CPU/64G内存,4核CPU/32G内存);65536(4核CPU/16G内存)

推荐计算公式:热点DB个数和线程个数的最小值乘以每个DB分配的内存大小

即global_syscache_threshold = min(count(hot dbs),count(threads)) * memofdb

热点DB数即访问较为频繁的数据库,线程数在线程池模式下取线程池线程个数和后台线程个数之和,非线程池模式不需要计算这个值,直接使用热点DB数。

memofdb即平均每个db应该分配的内存,每个DB的底噪内存是2M,平均每增加一个表或者索引,增加11k内存。

如果设置的值过小,会导致内存频繁淘汰,内存存在大量碎片无法回收,导致内存控制失效。

相关文档