Connected to Oracle Database 11g Enterprise Edition Release 11.2.0.1.0
Connected as system
SQL> show parameter target;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
archive_lag_target integer 0
db_flashback_retention_target integer 1440
fast_start_io_target integer 0
fast_start_mttr_target integer 0
memory_max_target big integer 2G
memory_target big integer 1904M
parallel_servers_target integer 16
pga_aggregate_target big integer 390M
sga_target big integer 512M
SQL> alter system set pga_aggregate_target=600m;
System altered
SQL> alter system set sga_target=712m;
System altered
SQL> show parameter target;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
archive_lag_target integer 0
db_flashback_retention_target integer 1440
fast_start_io_target integer 0
fast_start_mttr_target integer 0
memory_max_target big integer 2G
memory_target big integer 1904M
parallel_servers_target integer 16
pga_aggregate_target big integer 600M
sga_target big integer 712M
SQL>
AMM (自动内存管理)是用两个初始化参数进行配置的: MEMORY_TARGET:动态控制SGA和PGA时,Oracle总共可以使用的共享内存大小,这个参数是动态的,因此提供给Oracle的内存总量是
可以动态增大,也可以动态减小的。它不能超过MEMORY_MAX_TARGET参数设置的大
AMM(自动内存管理)是用两个初始化参数进行配置的:
MEMORY_TARGET:动态控制SGA和PGA时,Oracle总共可以使用的共享内存大小,这个参数是动态的,因此提供给Oracle的内存总量是可以动态增大,也可以动态减小的。它不能超过
MEMORY_MAX_TARGET参数设置的大小。默认值是0。
MEMORY_MAX_TARGET:这个参数定义了MEMORY_TARGET最大可以达到而不用重启实例的值,如果没有设置MEMORY_MAX_TARGET值,默认等于MEMORY_TARGET的值。
使用动态内存管理时,SGA_TARGET和PGA_AGGREGATE_TARGET代表它们各自内存区域的最小设置,要让Oracle完全控制内存管理,这两个参数应该设置为0。
CONN SYS/PASSWORD AS SYSDBA
-- Set the static parameter. Leave some room for possible future growth without restart.
ALTER SYSTEM SET MEMORY_MAX_TARGET=6G SCOPE=SPFILE;
-- Set the dynamic parameters. Assuming Oracle has full control.
ALTER SYSTEM SET MEMORY_TARGET=5G SCOPE=SPFILE;
ALTER SYSTEM SET PGA_AGGREGATE_TARGET=0 SCOPE=SPFILE;
ALTER SYSTEM SET SGA_TARGET=0 SCOPE=SPFILE;
-- Restart instance.
SHUTDOWN IMMEDIATE;
STARTUP;
因为在32位的机器上Oracle的内存有限制,内存最大4G,32位留50%给操作系统,window是单线程的,不能超过1.7G。也是就是说MEMORY_TARGET、MEMORY_MAX_TARGET最大只能设置为1.7G,
如果超过了,修改生效后,连接数据库时会提示:
ORA-27102: out of memory
OSD-00022: Message 22 not found; product=RDBMS; facility=SOSD
O/S-Error: (OS Not enough storage is available to process this command.
那么碰到这个问题我们如何解决了。如果了解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’;
重启服务,即可。
AMM(自动内存管理)是用两个初始化参数
猜你喜欢
转载自qinxiaohj.iteye.com/blog/1632427
今日推荐
周排行