oracle 禁用asmm,oracle三对内存参数间关系之3AMM启动和关闭两种情况下ASMM机制涉…[通俗易懂]

oracle 禁用asmm,oracle三对内存参数间关系之3AMM启动和关闭两种情况下ASMM机制涉…[通俗易懂]ASMM机制涉及的一对参数为:SGA_TARGET和SGA_MAX_SIZE。SGA_TARGETDefaultvalue0(SGAautotuningisdisabledforDEFERREDmodeautotuningrequests,butallowedforIMMEDIATEmodeautotuningrequests)ModifiableA…

大家好,又见面了,我是你们的朋友全栈君。

ASMM机制涉及的一对参数为: SGA_TARGET和SGA_MAX_SIZE 。 SGA_TARGET Default value 0 (SGA autotuning is disabled for DEFERRED mode autotuning requests, but allowed for IMMEDIATE mode autotuning requests) Modifiable ALTER SYSTEM (即表示该参数

ASMM机制涉及的一对参数为:SGA_TARGET和SGA_MAX_SIZE。

SGA_TARGET

Default value

0 (SGA autotuning is disabled forDEFERRED mode autotuning requests, but allowed forIMMEDIATE mode autotuning requests)

Modifiable

ALTER SYSTEM(即表示该参数为动态参数)

Range of values

64 MB to operating system-dependent

参见:http://docs.oracle.com/cd/E11882_01/server.112/e40402/initparams236.htm#I1010256

SGA_MAX_SIZE

Default value

Initial size of SGA at startup, dependent on the sizes of different pools in the SGA, such as buffer cache, shared pool, large pool, and so on.

Modifiable

No(即表示该参数为静态参数)

Range of values

0 to operating system-dependent

On 64-bit platforms and non-Windows 32-bit platforms, when either MEMORY_TARGET orMEMORY_MAX_TARGET is specified, the default value ofSGA_MAX_SIZE is set to the larger of the two parameters. This causes more address

space to be reserved for expansion of the SGA.

On Windows 32-bit platforms, the default value of SGA_MAX_SIZE is the largest of the following values:

60% of MEMORY_TARGET, if specified

60% of MEMORY_MAX_TARGET, if specified

25% of the total available virtual address space

参见:http://docs.oracle.com/cd/E11882_01/server.112/e40402/initparams235.htm

上述描述可知,

1、当SGA_TARGET=非0时,SGA_TARGET要在64 MB to operating system-dependent这个范围内,确切说是,SGA_TARGET要在64 MB toSGA_MAX_SIZE。

2、

由于SGA_TARGET始终<=SGA_MAX_SIZE,所以

当SGA_TARGET=0时,SGA_MAX_SIZE取值范围为0 toSGA_MAX_SIZE。

当SGA_TARGET=非0时,SGA_TARGET要在64 MB toSGA_MAX_SIZE这个范围内,故而SGA_MAX_SIZE取值范围为64

MB to operating system-dependent。

说明了SGA_TARGET要<=SGA_MAX_SIZE的例子,参见下文一大点里1.2的例子。

这里还有一点要知道,sga_max_size可以自动来变动的(sga_max_size自动变动值,无论在实例启动时,还是实例运行期间,都可以;而alter system setsga_max_size只能在实例启动时起效,因为sga_max_size是静态参数),当sga的内存组件的和小于sga_max_size的时候,sga_max_size不会改变,还是维持自己的值,如果超过了这个和,sga_max_size的就会自动变动成和的值,这个你可以自己试试。例如,

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

SQL>alter system set db_cache_size=1000Mscope=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

也已经变化叻。

参见:

http://blog.csdn.net/haiross/article/details/41696485

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

SGA不能超过1.7G的限制

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

当实例启动前的参数里sga_max_size=0,sga_target=0时,实例启动后sga_max_size值也会自动调整,详见下文一大点里的2.2例子。

那么sga_max_size值自动调整时,该参数的值具体为多少,是什么决定呢?

是由sga_max_size的默认值:

Default value :Initial size of SGA at startup, dependent on the sizes of different pools in the SGA, such as buffer cache, shared pool, large pool, and so on。也就是说

SGA_MAX_SIZE 的 Default value 为Initial size of SGA at startup,所以说SGA_MAX_SIZE是一个没有初始化值的变量。故而在ASMM启动时,SGA_MAX_SIZE 的 Default value 是将SGA_target的值赋值给SGA_MAX_SIZE的,在ASMM关闭时,SGA_MAX_SIZE 的 Default

value 是将sga各个组件的参数值如shared_pool_size相加的值赋值给SGA_MAX_SIZE的。

具体的说是,

On 64-bit platforms and non-Windows 32-bit platforms, when either MEMORY_TARGET orMEMORY_MAX_TARGET is specified, the default value ofSGA_MAX_SIZE is set to the larger of the two parameters. This causes more address

space to be reserved for expansion of the SGA.

On Windows 32-bit platforms, the default value of SGA_MAX_SIZE is the largest of the following values:

60% of MEMORY_TARGET, if specified

60% of MEMORY_MAX_TARGET, if specified

25% of the total available virtual address space

实例运行期间的SGA_MAX_SIZE都是一个非0值,因为SGA_MAX_SIZE是一个静态参数,所以实例运行期间将SGA_MAX_SIZE置为0,但是修改后的值不会立马起效,只有待下一次实例启动时才起效,而待下一次实例启动时如上所说实例启动时SGA_MAX_SIZE还是会从0被调整为一个非0值。详见下文一大点里的2.2例子。

注释:

参数默认值不一定就是参数的初始化值:

SGA_MAX_SIZE Default value 为Initial size of SGA at startup,所以说SGA_MAX_SIZE是一个没有初始化值的变量。故而在ASMM启动时,SGA_MAX_SIZE 的 Default value 是将SGA_target的值赋值给SGA_MAX_SIZE的,在ASMM关闭时,SGA_MAX_SIZE 的 Default value 是将sga各个组件的参数值如shared_pool_size相加的值赋值给SGA_MAX_SIZE的。

参见盖国强 《深入解析oracle》 第二章 参数分类

SGA_TARGET和SGA_MAX_SIZE两者关系为

0、SGA_TARGET始终<=SGA_MAX_SIZE。

否则,会提示

ORA-00823: Specified value ofsga_target greater than sga_max_size。

一、

当AMM启动时,即memory_target=非0

If Automatic Memory Management is enabled (MEMORY_TARGET is set to a positive value) andSGA_TARGET is also set to a positive value, theSGA_TARGET value acts as the minimum value for the size of the SGA.

以下实验时参数文件里MEMORY_TARGET=非0,MEMORY_MAX_TARGET=非0。

1、当SGA_TARGET=非0时(即ASMM启动时)

1.1

当参数文件里SGA_TARGET=非0,SGA_MAX_SIZE=非0时,实例启动成功。

1.2

当参数文件里SGA_TARGET=非0,SGA_MAX_SIZE=0时,实例启动不成功。

下面是具体实验来证明:

参数文件里:

*.memory_max_target= 700M

*.memory_target=700M

*.sga_max_size=0

*.sga_target=400M

*.pga_aggregate_target=100M

SQL>shutdown immediate

数据库已经关闭。

已经卸载数据库。

ORACLE例程已经关闭。

SQL>startup pfile=E:\app\hc\product\11.2.0\dbhome_1\database\INITmonkey.ORA

ORA-00823: Specified value of sga_target greater than sga_max_size

ORA-01078:处理系统参数失败

SQL>

注释:

对比memory_max_target和memory_target关系不同点在于:

当MEMORY_TARGET=非0,MEMORY_MAX_TARGET=0时,启动实例后MEMORY_MAX_TARGET=MEMORY_TARGET值。

2、当SGA_TARGET=0时(即ASMM关闭时)

2.1

当参数文件里SGA_TARGET=0,SGA_MAX_SIZE=非0时,实例启动成功。

注释:

memory_target=0时sga_target可以为0是因为memory_target=0时sga_target为0,表示sga为手动管理,即由shared_pool_size参数等之和为sga大小。

2.2

当参数文件里SGA_TARGET=0,SGA_MAX_SIZE=0时,实例启动成功。

启动实例成功后,查看SGA_TARGET和SGA_MAX_SIZE(使用showparameters

sga或是select * from v$parameter where name like ‘%sga%’;),发现SGA_MAX_SIZE被调整为一个非0值。

下面是具体实验来证明:

以如下参数文件来启动实例:

memory_target=0,memory_max_target=1400M,

pga_aggregate_target为0,workarea_size_policy=manual,

sga_max_size=0,sga_target=0

则可以启动实例成功。

SQL> select name,value from v$parameter where name like ‘%target%’ orname like

‘%sga%’;

NAME VALUE

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

sga_max_size 150994944

pre_page_sga FALSE

lock_sga FALSE

sga_target 0

memory_target 0

memory_max_target 1468006400

archive_lag_target 0

fast_start_io_target 0

fast_start_mttr_target 0

db_flashback_retention_target 1440

pga_aggregate_target 0

parallel_servers_target 32

已选择12行。

注释:

为什么启动实例时SGA_MAX_SIZE会从0被调整为一个非0值呢?

因为

sga_max_size可以自动来变动的(sga_max_size自动变动值,无论在实例启动时,还是实例运行期间,都可以;而alter system setsga_max_size只能在实例启动时起效,因为sga_max_size是静态参数),当sga的内存组件的和小于sga_max_size的时候,sga_max_size不会改变,还是维持自己的值,如果超过了这个和,sga_max_size的就会自动变动成和的值。

那么sga_max_size值自动调整时,该参数的值具体为多少,是什么决定呢?

是由sga_max_size的默认值。

SGA_MAX_SIZE Default value 为Initial size of SGA at startup,所以说SGA_MAX_SIZE是一个没有初始化值的变量。故而在ASMM启动时,SGA_MAX_SIZE 的 Default value 是将SGA_target的值赋值给SGA_MAX_SIZE的,在ASMM关闭时,SGA_MAX_SIZE 的 Default value 是将sga各个组件的参数值如shared_pool_size相加的值赋值给SGA_MAX_SIZE的。

所以,实例启动前的参数文件即使设置了SGA_MAX_SIZE=0,实例启动时SGA_MAX_SIZE也会从0被调整为一个非0值。

故而我们可以知道实例运行期间的SGA_MAX_SIZE都是一个非0值,因为SGA_MAX_SIZE是一个静态参数,所以实例运行期间将SGA_MAX_SIZE置为0,但是修改后的值不会立马起效,只有待下一次实例启动时才起效,而待下一次实例启动时如上所说实例启动时SGA_MAX_SIZE还是会从0被调整为一个非0值。

二、

当AMM关闭时,即memory_target=0

2、当MEMORY_TARGET=0时(即AMM关闭时)

2.1

当参数文件里MEMORY_TARGET=0,MEMORY_MAX_TARGET=非0时,实例启动成功。

实例启动后,查看MEMORY_TARGET和MEMORY_MAX_TARGET都为原值(使用showparameters mem或是select * from v$parameter where name like ‘%mem%’;)。即

If you omit the line for MEMORY_TARGET and include a value forMEMORY_MAX_TARGET, theMEMORY_TARGET parameter defaults to zero. After startup, you can then dynamically changeMEMORY_TARGET

to a nonzero value, provided that it does not exceed the value ofMEMORY_MAX_TARGET.(文章详解)

2.2

当参数文件里MEMORY_TARGET=0,MEMORY_MAX_TARGET=0时,实例启动成功。

实例启动后,查看MEMORY_TARGET和MEMORY_MAX_TARGET(使用showparameters mem或是select * from v$parameter where name like ‘%mem%’;),发现MEMORY_MAX_TARGET被调整为一个非0值。

下面是具体实验来证明:

三、

AMM关闭时(即memory_target=0),才会出现ORA-00849:SGA_TARGET

524288000 cannot be set to more than MEMORY_MAX_TARGET 0.无论是sga_target>memory_max_target还是sga_max_size>memory_max_target。当sga_max_size>memory_max_target时,即使此时sga_target也>memory_max_target,ORA-00849里的SGA_TARGET值还是来自sga_max_size。

附加

sga_max_size是静态参数,所以它即使在实例运行期间修改的值也要在下次启动时起作用,故而不用试验sga_max_size静态参数在实例运行期间修改对sga_target影响。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/135267.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 进程之间的通信方式「建议收藏」

    进程之间的通信方式「建议收藏」进程间通信方式一般有以下几种:1、管道,匿名管道,命名管道2、信号3、信号量4、消息队列5、共享内存6、socket管道管道数据只能单向流动,所以如果要实现双向通信,就要创建2个管道管道分为匿名管道和命名管道匿名管道只能在父子进程关系之间使用命名管道,可以在不关联的两个进程之间使用,因为它创建了一个类型为管道的设备文件,使用这个设备文件就可以通信。管道只能承载无格式的字节流信号信号是进程之间唯一的异步通信机制,信号的主要来源主要有硬件来源(入键盘操作ctrl+C)

    2022年10月11日
    5
  • 详解java接口interface

    详解java接口interface引言接口这个词在生活中我们并不陌生。在中国大陆,我们可以将自己的家用电器的插头插到符合它插口的插座上;我们在戴尔,惠普,联想,苹果等品牌电脑之间传输数据时,可以使用U盘进行传输。插座的普适性是

    2022年7月2日
    23
  • Vue(4)Vue指令的学习1「建议收藏」

    Vue(4)Vue指令的学习1「建议收藏」前言Vue官网一共有提供了14个指令,分别如下v-textv-htmlv-showv-if☆☆☆v-else☆☆☆v-else-if☆☆☆v-for☆☆☆v-on☆☆☆v

    2022年7月31日
    5
  • 我们可以使用命令kill来结束Linux系统下运行的进程(kill强制杀死进程)

    杀死进程最安全的方法是单纯使用kill命令,不加修饰符,不带标志。首先使用ps-ef命令确定要杀死进程的PID,然后输入以下命令:#kill–pid注释:标准的kill命令通常都能达到目的。终止有问题的进程,并把进程的资源释放给系统。然而,如果进程启动了子进程,只杀死父进程,子进程仍在运行,因此仍消耗资源。为了防止这些所谓的“僵尸进程”,应确保在杀死父进程之前,先杀死其所有的子进程。确定要杀死进程的PID或PPID#ps-ef|grephttpd以优雅的方式结束进

    2022年4月16日
    80
  • LoadRunner详细使用教程

    LoadRunner详细使用教程文章目录VirturalUserGeneratorControllerAnalysisloadrunner的使用VirturalUserGenerator:录制脚本Controller:场景测试,收集并发测试的数据(多个用户并发场景)Analysis:分析系统并发测试的数据,生成报告和图标loadrunner做性能测试的原理?性能测试主要是多用户的并发,就是多线程模拟用户的操作,什么是集合点,为什莫需要集合点?因为先初始化好的线程需要等待后面还没初始化好的线程,所以设置一个集合点

    2022年5月23日
    65
  • python中merge函数「建议收藏」

    python中merge函数「建议收藏」merge函数用来合并下面我们看看长什么样子merge(left,right,how=’inner’,on=None,left_on=None,right_on=None,left_index=False,right_index=False,sort=False,suffixes=(‘_x’,’_y’),copy=True,indicator=False,valida…

    2022年6月1日
    56

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号