1.
Heap 参数(global)
gbase_heap_data 主要设计用途是缓存数据(DC),应分配最多的内存。
gbase_heap_large 用于管理不频繁申请、释放的内存。
gbase_heap_temp 用来分配较为琐碎的和小块儿的临时内存,较少使用。
gbase_memory_pct_target 设置内存的可用比例,默认0.8。
参数下限:
gbase_heap_data
>= 512MB
gbase_heap_large
>= 256MB
gbase_heap_temp
>= 256MB
参数上限:
(gbase_heap_data + gbase_heap_large + gbase_heap_temp ) <= total memory *
gbase_memory_pct_target
GBase 8a MPP Cluster 产品手册
5 数据库管理指南
文档版本953(2022-04-10)
南大通用数据技术股份有限公司
1286
注意
默认:
total memory = physical memory
_gbase_memory_use_swap 设置为1 时:
total memory = physical memory + swap
2.
算子buffer(session)
算子buffer 均为session 级别,即如果设置gbase_buffer_result=1G,且并发数
为30,则在执行并发的过程中,30 并发总共占用的gbase_buffer_result 就为
1G*30 = 30G,而且是在不计算其他的算子buffer 的情况下。
所以如果在高并发环境中将某一个算子buffer 设置很大的话,很有可能就会
出现内存不足无法分配的情况。
常用的buffer 如下:
•
gbase_buffer_distgrby:用于保存distinct 操作的中间结果;
•
gbase_buffer_hgrby:用于保存shash group by 操作的中间结果;
•
gbase_buffer_hj:用于保存hash join 操作的中间结果;
•
gbase_buffer_insert:用于保存insert values 的中间结果;
•
gbase_buffer_result:用于保存物化的中间结果;
•
gbase_buffer_rowset:用于保存join 计算的中间结果集;
•
gbase_buffer_sj:
用于保存sort merge join 的中间结果,
当join 条件是a>=b
或者a<=b 时,可能会使用sort merge join;
•
gbase_buffer_sort:用于保存sort 操作的中间结果。
算子buffer 的设置原则:
一般情况下(非高并发场景),根据系统内存大小,算子buffer 可以按照如
下方法设置:
•
gbase_buffer_hgrby 和gbase_buffer_hj 最大不超过4G;
•
gbase_buffer_result 最大不超过2G;
•
gbase_buffer_rowset 最大不超过1G;
•
其他算子使用系统估算即可。
•
如果在高并发场景下,则不需要设置过大的算子buffer,一般以系统自
动评估为准。但如果并发数过大,不排除需要人为将算子buffer 设置更
小的情况。即并发数乘以总算子buffer 大小不超过gbase_heap_large 为
宜,但最大也不能超过系统总内存大小。
修改算子buffer 的其它场景:
如果某条sql 由于某个算子执行过慢(瓶颈点可参考单机trace),可以适当
调大与之对应算子buffer。例如根据trace 发现join 较慢,可以适当调大
GBase 8a MPP Cluster 产品手册
5 数据库管理指南
文档版本953(2022-04-10)
南大通用数据技术股份有限公司
1287
gbase_buffer_hj 的值。但是需要注意,调整该值时必须不能影响其他SQL 的
执行。