ORA-27102: out of memory 解决实例

最开始一次给客户做优化设置的时候,出现过一个这样的错,那时候没有经验,数据库怎么都起不来,自己吓得不行了,回来幸好找到一个有经验的前辈,才得以解决。

时间几年过去了,再也没有发生,这几天忽然想起一起那次的事,不由的想把当时的情况模拟出来,自己来处理一次叻。

问题是怎么出现的,

首先在32位机器上,配置sga的内存超过1.5G,基本上就出现这个问题叻

这里还有一点要知道,sga_max_size可以自动来变动的,当sga的内存组件的和小于sga_max_size的时候,sga_max_size不会改变,还是维持自己的值,如果超过了这个和,sga_max_size的就会自动变动成和的值,这个你可以自己试试。

看看我的内存情况

Total System Global Area  965812724 bytes

Fixed Size                   455156 bytes

Variable Size             251658240 bytes

Database Buffers          713031680 bytes

Redo Buffers                 667648 bytes

这是我的windowxp上的实例,

我现在想调整database buffer的值到1G,我只需要设置db_cache_size到1G,而不设置sga_max_size,这时由于各组件值大于sga_max_size目前值,所以sga_max_size自动变化:

SQL>alter system set db_cache_size=1000M scope=spfile;

SQL> shutdown immediate;

SQL> startup;

看看现在的内存信息

Total System Global Area 1301357848 bytes

Fixed Size                   455960 bytes

Variable Size             251658240 bytes

Database Buffers         1048576000 bytes

Redo Buffers                 667648 bytes

发现sga_max_size已经自动变化

SQL> show parameters sga_

NAME                                 TYPE                              VALUE

———————————— ——————————— ———

sga_max_size                         big integer                       130135784

也已经变化叻。

 

现在模拟我们的问题吧

不过模拟前,先把我们的init.Ora备份一下,不备份init.Ora当然也不可以不过,等下恢复设置的东西太多,麻烦。

先把我们调整内存钱的parameter备份一下吧

SQL>create  pfile=’F:/Synchrophy/Server/oracle/admin/ORA9i/pfile/init.bak.ora’ from spfile;

这句话就是把你的spfile备份到pfile文件里,由于spfile是二进制的文件,不好修改,所以我们一般用这样的形式来备份。

备份好。我们可以放心的改我们的内存叻

SQL> alter system set db_cache_size=1500M scope=spfile;

SQL> shutdown immediate;

SQL> startup;

现在问题出现了吧

一起看看

ORA-27102: out of memory

OSD-00022: Message 22 not found;  product=RDBMS; facility=SOSD

O/S-Error: (OS 8) Not enough storage is available to process this command.

为什么会出现这样的问题叻,是因为在32位的机器上Oracle的内存有限制,内存最大4G,32位留50%给操作系统,window是单线程的,不能超过1.7G。out of memory也就出来叻。

参见: SGA不能超过1.7G的限制


在Windows上调整SGA大小遭遇ORA-27100、ORA-27102错误的处理方法

那么碰到这个问题我们如何解决了。如果了解Oracle的init的启动的话,做这个恢复就比较简单了,默认oralce是从spfile先启动的,

你可以这样查到路径

SQL> show parameter pfile

 

NAME                                 TYPE        VALUE

———————————— ———– ——————————

spfile                               string      %ORACLE_HOME%/DATABASE/SPFILE%

                                                 ORACLE_SID%.ORA

所以你先在可以通过修改这个文件里的相关参数的值来恢复,不过修复的时候注意,这是个二进制文件,要保持二进制的格式。

还有方法用我们刚才的pfile来恢复。

SQL>startup pfile=’你备份的init.ora’;

如果在window下,需要

SQL>create spfile from pfile=’你备份的init.ora’;

重启服务,即可。

附加:

笔者遇到ORA-27102: out of memory问题时,除了修改参数文件里相关参数的值外,还要先关闭oracle实例对应的Windows服务,否则启动实例还是会报错:ORA-27102: out of memory

难道pga和sga等oracle申请的内存总和只会不断扩张,不会缩小吗?只有通过关闭oracle实例对应的Windows服务来把oracle.exe进程关闭掉而释放它占用的内存?

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值