首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >ORA-04036:实例使用的PGA内存超过PGA_AGGREGATE_LIMIT

ORA-04036:实例使用的PGA内存超过PGA_AGGREGATE_LIMIT
EN

Stack Overflow用户
提问于 2017-03-17 18:27:21
回答 2查看 92K关注 0票数 6

当我的一个团队成员创建oracle文本索引时,我遇到了ORA-04036 (在12c上)。

代码语言:javascript
运行
复制
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
EN

回答 2

Stack Overflow用户

发布于 2017-03-17 18:27:21

在我的例子中,创建索引(或任何其他并行操作)时,由于并行度非常高(需要太多会话和增加的PGA),它失败了。我们应该尽量减少并行度来避免这种情况。我尝试用DOP 8脚本运行成功。

在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,该参数就不会有任何影响。

为了社区读者的兴趣而张贴答案,因为我还没有找到它。请参阅this了解更多信息...

票数 9
EN

Stack Overflow用户

发布于 2017-06-29 23:33:49

我遇到了类似的问题,并通过执行以下操作解决了它。

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

代码语言:javascript
运行
复制
show parameter pga_aggregate_limit;

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

代码语言:javascript
运行
复制
alter system set pga_aggregate_limit = 0; 

此处提供了更多信息:

http://www.dba-oracle.com/t_pga_aggregate_limit.htm

https://docs.oracle.com/database/121/REFRN/GUID-E364D0E5-19F2-4081-B55E-131DF09CFDB3.htm#REFRN10328

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42855051

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档