重庆思庄Oracle、Redhat认证学习论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1855|回复: 0
打印 上一主题 下一主题

[Oracle] ORA-04036:实例使用的PGA内存超过PGA_AGGREGATE_LIMIT

[复制链接]
跳转到指定楼层
楼主
发表于 2023-3-26 15:12:05 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 mahan 于 2023-3-26 15:13 编辑

创建oracle文本索引时,我遇到了ORA-04036 (在12c上)。

ORA-29855: error occurred in the execution of ODCIINDEXCREATE routine
ORA-20000: Oracle Text error:
ORA-00039: error during periodic action
ORA-04036: PGA memory used by the instance exceeds PGA_AGGREGATE_LIMIT
ORA-06512: at "CTXSYS.DRUE", line 160
ORA-06512: at "CTXSYS.TEXTINDEXMETHODS", line 366


在Oracle数据库12c中,一个名为PGA_AGGREGATE_LIMIT的新参数对实例占用的数量设置了硬性限制。当该实例中所有会话占用的PGA总量超过限制时,Oracle将终止占用最不可调的PGA内存的会话,并释放该会话占用的所有PGA内存。被杀死的会话会收到这样的消息。


请注意新的Oracle错误ORA-4036。这是一个非常有用的特性,可以通过会话发出未调优的查询来控制失控的PGA消耗。如果未显式定义参数pga_aggregate_limit,则默认为这三个数字中较大的一个:2 GB 3MB乘以processes参数的值2乘以参数pga_aggregate_target的值,但此限制不超过去掉总SGA大小后的总物理内存的1.2倍。不喜欢这个新功能,想回到以前(12c之前)的行为?当然可以;只要将pga_aggregate_limit的值设置为0,该参数就不会有任何影响。

使用以下命令查看当前的pga_aggregate_limit (以防您想要恢复更改):

show parameter pga_aggregate_limit;

使用以下命令将pga_aggregate_limit设置为0:

alter system set pga_aggregate_limit = 0;
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 支持支持 反对反对
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|手机版|小黑屋|重庆思庄Oracle、Redhat认证学习论坛 ( 渝ICP备12004239号-4 )

GMT+8, 2024-8-10 06:38 , Processed in 0.105323 second(s), 20 queries .

重庆思庄学习中心论坛-重庆思庄科技有限公司论坛

© 2001-2020

快速回复 返回顶部 返回列表