人大金仓数据库KingbaseES配置进程全局区内存

本文详细介绍了KingbaseES数据库中SGA(系统全局区)和PGA(进程全局区)的概念,以及如何配置临时页面缓存、工作内存和维护工作内存。提供相关参数设置方法和参考文档链接。
摘要由CSDN通过智能技术生成

KingbaseES配置进程全局区内存

关键字:

数据库实例、内存管理、内存配置、人大金仓、KingbaseES

一、摘要

本文对KingbaseES配置进程全局区内存进行了介绍。

内存结构

KingbaseES数据库中,相关的基本内存结构包括:

系统全局区(简写为SGA):SGA是一组共享内存结构,其中包含一个KingbaseES数据库实例的数据和控制信息。SGA由所有服务器和后台进程共享。存储在SGA中的数据包括数据块缓冲区和重做日志缓冲区等。

进程全局区(简写为PGA):PGA是包含单个服务进程的数据和控制信息的内存区域。它是在启动服务进程时创建的非共享内存。只有该服务进程可以对本PGA进行访问。每个服务进程都有一个PGA,每个后台进程也会有自己的PGA。一个实例中所有PGA的总和称为实例PGA。存储在PGA中的数据包括排序和哈希操作可使用的工作内存等。。

配置系统全局区内存

进程全局区的内存配置包括临时页面缓存、工作内存、维护工作内存及临时分配的内存的配置。

临时页面缓存

在进程私有内存中用于缓存临时表的数据页面的大小,由temp_buffers参数控制其大小。

采用以下方式查看临时页面缓存大小:

SHOW temp_buffers;

采用以下方式修改临时页面缓存大小:

ALTER SYSTEM SET temp_buffers = '16MB';

重启数据库后生效。

工作内存

服务器对元组进行排序或者连接运算时,需要在PGA中缓存临时结果集数据,这部分内存称为工作内存。如果工作内存空间不足,数据库会转由临时文件存储这部分数据。参数work_mem设置每个服务进程的工作内存大小。工作内存只在正在进行排序或者连接运算的服务进程中被分配,并会随着运算结束而释放。

采用以下方式查看工作内存大小:

SHOW work_mem;

采用以下方式修改工作内存大小:

ALTER SYSTEM SET work_mem = '16MB';

重启数据库后生效。

维护工作内存

在维护性操作(比如VACUUM、CREATE INDEX、ALTER TABLE ADD FOREIGN KEY 等)中使用的最大的内存空间。参数maintenance_work_mem设置维护工作内存的大小。默认是64MB。 较大的维护工作内存可以有效改进清理和恢复数据的速度。

采用以下方式查看维护工作内存大小:

SHOW maintenance_work_mem;

采用以下方式修改维护工作内存大小:

ALTER SYSTEM SET maintenance_work_mem = '256MB';

重启数据库后生效。

临时分配的内存

数据库在执行SQL过程中,用于临时存放控制信息及数据所使用的内存。此部分内存动态分配和释放,并受到内存上下文管理。此部分内存大小不可配置。

参考文档:

KingbaseES V8用户手册

  • 22
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值