关于SGA4个参数的学习

首先看看4个参数

SQL> show parameter sga;

NAME                                 TYPE        VALUE
------------------------------------ ----------- ----------
lock_sga                             boolean     FALSE
pre_page_sga                         boolean     FALSE
sga_max_size                         big integer 712M
sga_target                           big integer 0

 

我用的版本是

SQL> select * from v$version;

BANNER
---------------------------------------------------------------------------

Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
PL/SQL Release 11.2.0.1.0 - Production
CORE    11.2.0.1.0      Production
TNS for 32-bit Windows: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production

 

看别人总结的在11.1版本中,如果设置了sga_target,那么默认会将sga_target的值设置成为sga_max_size;

但是我在我的环境上却不是如此。

 

    一般OS分配给sga的内存区是由物理内存和虚拟内存组成的,但是如果我有足够的物理内存,不希望使用虚拟内存,那么可以调整lock_sga和pre_page_sga参数。

由于这2个参数是静态的,所以更改如下

SQL> alter system set lock_sga=true scope=spfile;

系统已更改。

SQL> alter system set pre_page_sga=true scope=spfile;

系统已更改。

shutdown immediate;

 

但是在启动的时候出现了问题:

startup
ORA-00847: MEMORY_TARGET/MEMORY_MAX_TARGET and LOCK_SGA cannot be set together

 

由于练习时候将sga_target设置成了值,开启AMM。但是我又设置为0了(难道设置为0不是关闭AMM吗?),但似乎还是触发了这个bug。

解决方法只需要重建一个spfile即可:

采用Pfile方式打开数据库
startup pfile ='E:\app\Richard\product\11.2.0\dbhome_1\dbs\init.ora'
重建spfile
SQL> create spfile='E:\app\Richard\product\11.2.0\dbhome_1\database\spfileorcl.o
ra' from pfile ='E:\app\Richard\product\11.2.0\dbhome_1\database\init.ora';

shutdown immediate

startup

 

lock_sga作用:保证运行时sga不使用虚拟内存。

pre_page_sga作用:保证启动时sga全部放到虚拟内存中,但是会延长实例启动时间。

 

 

 

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值