SGA_TARGET vs SGA_MAX_SIZE
SGA_MAX_SIZE
sga_max_size sets the maximum value for sga_target
If sga_max_size is less than the sum of db_cache_size + log_buffer + shared_pool_size + large_pool_size at initialization time, then the value of sga_max_size is ignored.
SGA_TARGET
This parameter is new with Oracle 10g. It specifies the total amaount of SGA memory available to an instance. Setting this parameter makes Oracle distribute the available memory among various components - such as shared pool (for SQL and PL/SQL), Java pool, large_pool and buffer cache - as required.
This new feature is called Automatic Shared Memory Management. With ASMM, the parameters java_pool_size, shared_pool_size, large_pool_size and db_cache_size need not be specified explicitely anymore.
sga_target cannot be higher than sga_max_size.
SGA_TARGET is a database initialization parameter (introduced in Oracle 10g) that can be used for automatic SGA memory sizing.
Parameter description:
SGA_TARGET
Property Description
Parameter type Big integer
Syntax SGA_TARGET = integer [K | M | G]
Default value 0 (SGA autotuning is disabled)
Modifiable ALTER SYSTEM
Range of values 64 to operating system-dependent
Basic Yes
SGA_TARGET provides the following:
• Single parameter for total SGA size
• Automatically sizes SGA components
• Memory is transferred to where most needed
• Uses workload information
• Uses internal advisory predictions
• STATISTICS_LEVEL must be set to TYPICAL
By using one parameter we don't need to use all other SGA parameters like.
sga_max_size sets the maximum value for sga_target
If sga_max_size is less than the sum of db_cache_size + log_buffer + shared_pool_size + large_pool_size at initialization time, then the value of sga_max_size is ignored.
SGA_TARGET
This parameter is new with Oracle 10g. It specifies the total amaount of SGA memory available to an instance. Setting this parameter makes Oracle distribute the available memory among various components - such as shared pool (for SQL and PL/SQL), Java pool, large_pool and buffer cache - as required.
This new feature is called Automatic Shared Memory Management. With ASMM, the parameters java_pool_size, shared_pool_size, large_pool_size and db_cache_size need not be specified explicitely anymore.
sga_target cannot be higher than sga_max_size.
SGA_TARGET is a database initialization parameter (introduced in Oracle 10g) that can be used for automatic SGA memory sizing.
Parameter description:
SGA_TARGET
Property Description
Parameter type Big integer
Syntax SGA_TARGET = integer [K | M | G]
Default value 0 (SGA autotuning is disabled)
Modifiable ALTER SYSTEM
Range of values 64 to operating system-dependent
Basic Yes
SGA_TARGET provides the following:
• Single parameter for total SGA size
• Automatically sizes SGA components
• Memory is transferred to where most needed
• Uses workload information
• Uses internal advisory predictions
• STATISTICS_LEVEL must be set to TYPICAL
By using one parameter we don't need to use all other SGA parameters like.
• DB_CACHE_SIZE (DEFAULT buffer pool)
• SHARED_POOL_SIZE (Shared Pool)
• LARGE_POOL_SIZE (Large Pool)
• JAVA_POOL_SIZE (Java Pool)
Enable SGA_TARGET
SQL> show parameter sga_target
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
sga_target big integer 0
SQL> show parameter sga_max_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
sga_max_size big integer 600M
As we can see out automatic SGA tuning is not enabled so we can enable it by setting the SGA_TARGET parameter value.
SQL> show parameter sga_target
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
sga_target big integer 0
SQL> show parameter sga_max_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
sga_max_size big integer 600M
As we can see out automatic SGA tuning is not enabled so we can enable it by setting the SGA_TARGET parameter value.
SQL> alter system set sga_target=500m;
System altered.
SQL> show parameter sga_target
NAME TYPE VALUE
------------------------------------ -----------
sga_target big integer 500
Resize SGA_TARGET
• SGA_TARGET is dynamic
• Can be increased till SGA_MAX_SIZE
• Can be reduced till some component reaches minimum size
• Change in value of SGA_TARGET affects only automatically sized components
• SGA_TARGET is dynamic
• Can be increased till SGA_MAX_SIZE
• Can be reduced till some component reaches minimum size
• Change in value of SGA_TARGET affects only automatically sized components
SQL> show parameter sga_max_size
NAME TYPE VALUE
------------------------------------ ----------- -----------
sga_max_size big integer 1G
NAME TYPE VALUE
------------------------------------ ----------- -----------
sga_max_size big integer 1G
SQL> show parameter sga_target
NAME TYPE VALUE
------------------------------------ ----------- -----------
sga_target big integer 1G
NAME TYPE VALUE
------------------------------------ ----------- -----------
sga_target big integer 1G
WE can resize it to only 1G if we will try to increase it from 2G we will get error.
SQL> alter system set sga_target=2G;
alter system set sga_target=2G *
ERROR at line 1:
ORA-02097: parameter cannot be modified because specified value is invalid
ORA-00823: Specified value of sga_target greater than sga_max_size
For that we must first increase our SGA_MAX_SIZE parameter value.But we must restart out instance because its STATIC parameter.
SQL> alter system set sga_target=2G;
alter system set sga_target=2G *
ERROR at line 1:
ORA-02097: parameter cannot be modified because specified value is invalid
ORA-00823: Specified value of sga_target greater than sga_max_size
For that we must first increase our SGA_MAX_SIZE parameter value.But we must restart out instance because its STATIC parameter.
SQL> alter system set sga_max_size=2G scope=spfile;
System altered.
SQL> startup force
ORACLE instance started.
Total System Global Area 1000189952 bytes
System altered.
SQL> startup force
ORACLE instance started.
Total System Global Area 1000189952 bytes
Fixed Size 1337492 bytes
Variable Size 624953196 bytes
Database Buffers 369098752 bytes
Redo Buffers 4800512 bytes
Database mounted.
Database opened.
SQL> show parameter sga_max_size
NAME TYPE VALUE
------------------------------------ ----------- --------
sga_max_size big integer 2G
SQL> alter system set sga_target=1900m;
System altered.
Disable SGA_TARGET
We can Disable our automatic SGA tuning by setting the parameter SGA_TARGET to value digit 0.
SQL> alter system set sga_target=0;
System altered.
Variable Size 624953196 bytes
Database Buffers 369098752 bytes
Redo Buffers 4800512 bytes
Database mounted.
Database opened.
SQL> show parameter sga_max_size
NAME TYPE VALUE
------------------------------------ ----------- --------
sga_max_size big integer 2G
SQL> alter system set sga_target=1900m;
System altered.
Disable SGA_TARGET
We can Disable our automatic SGA tuning by setting the parameter SGA_TARGET to value digit 0.
SQL> alter system set sga_target=0;
System altered.
[Reference Link: http://it-toolkit.blogspot.com/2013/08/resize-sga-oracle-11g.html]
PRACTICAL EXERCISE:
SQL> show parameter db_cache_size log_buffer shared_pool_size large_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_cache_size big integer 4G
SQL> show parameter log_buffer
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
log_buffer integer 5242880
SQL> show parameter shared_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
shared_pool_size big integer 4G
SQL> show parameter large_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
large_pool_size big integer 128M
SQL> alter system flush buffer_cache;
System altered.
SQL> alter system db_cache_size=2500M scope=both;
alter system db_cache_size=2500M scope=both
*
ERROR at line 1:
ORA-02065: illegal option for ALTER SYSTEM
SQL> alter system set db_cache_size=2500M scope=both;
alter system set db_cache_size=2500M scope=both
*
ERROR at line 1:
ORA-32018: parameter cannot be modified in memory on another instance
SQL> alter system db_cache_size=2500M scope=both sid='stg4cus1x02';
alter system db_cache_size=2500M scope=both sid='stg4cus1x02'
*
ERROR at line 1:
ORA-02065: illegal option for ALTER SYSTEM
SQL> alter system set db_cache_size=2500M scope=both sid='stg4cus1x02';
System altered.
SQL> alter system flush shared_pool;
System altered.
SQL> alter system set shared_pool_size=2500M scope=both sid='stg4cus1x02';
System altered.
SQL> alter system set sga_target=6000M sid='stg4cus1x02';
System altered.
SQL> alter system set sga_max_size=6000M sid='stg4cus1x02';
alter system set sga_max_size=6000M sid='stg4cus1x02'
*
ERROR at line 1:
ORA-02095: specified initialization parameter cannot be modified
SQL> alter system set sga_max_size=6000M sid='stg4cus1x02' scope=spfile;
System altered.
SQL> startup force;
ORA-00823: Specified value of sga_target greater than sga_max_size
SQL>
SOLUTION:
SQL> show parameter db_cache_size log_buffer shared_pool_size large_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_cache_size big integer 4G
SQL> show parameter log_buffer
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
log_buffer integer 5242880
SQL> show parameter shared_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
shared_pool_size big integer 4G
SQL> show parameter large_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
large_pool_size big integer 128M
SQL>
SQL> alter system flush buffer_cache;
System altered.
SQL> alter system set db_cache_size=2500M scope=both sid='stg4cus1x02';
System altered.
SQL> alter system flush shared_pool;
System altered.
SQL> alter system set shared_pool_size=2500M scope=both sid='stg4cus1x02';
System altered.
SQL> alter system set sga_target=6000M sid='stg4cus1x02';
System altered.
SQL> alter system set sga_max_size=6200M sid='stg4cus1x02' scope=spfile;
System altered.
SQL> startup force;
ORACLE instance started.
Total System Global Area 6480490496 bytes
Fixed Size 2265112 bytes
Variable Size 3254783976 bytes
Database Buffers 3204448256 bytes
Redo Buffers 18993152 bytes
Database mounted.
Database opened.
http://www.akadia.com/services/ora_asm_multiple_block_sizes.html
PRACTICAL EXERCISE:
SQL> show parameter db_cache_size log_buffer shared_pool_size large_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_cache_size big integer 4G
SQL> show parameter log_buffer
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
log_buffer integer 5242880
SQL> show parameter shared_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
shared_pool_size big integer 4G
SQL> show parameter large_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
large_pool_size big integer 128M
SQL> alter system flush buffer_cache;
System altered.
SQL> alter system db_cache_size=2500M scope=both;
alter system db_cache_size=2500M scope=both
*
ERROR at line 1:
ORA-02065: illegal option for ALTER SYSTEM
SQL> alter system set db_cache_size=2500M scope=both;
alter system set db_cache_size=2500M scope=both
*
ERROR at line 1:
ORA-32018: parameter cannot be modified in memory on another instance
SQL> alter system db_cache_size=2500M scope=both sid='stg4cus1x02';
alter system db_cache_size=2500M scope=both sid='stg4cus1x02'
*
ERROR at line 1:
ORA-02065: illegal option for ALTER SYSTEM
SQL> alter system set db_cache_size=2500M scope=both sid='stg4cus1x02';
System altered.
SQL> alter system flush shared_pool;
System altered.
SQL> alter system set shared_pool_size=2500M scope=both sid='stg4cus1x02';
System altered.
SQL> alter system set sga_target=6000M sid='stg4cus1x02';
System altered.
SQL> alter system set sga_max_size=6000M sid='stg4cus1x02';
alter system set sga_max_size=6000M sid='stg4cus1x02'
*
ERROR at line 1:
ORA-02095: specified initialization parameter cannot be modified
SQL> alter system set sga_max_size=6000M sid='stg4cus1x02' scope=spfile;
System altered.
SQL> startup force;
ORA-00823: Specified value of sga_target greater than sga_max_size
SQL>
SOLUTION:
SQL> show parameter db_cache_size log_buffer shared_pool_size large_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_cache_size big integer 4G
SQL> show parameter log_buffer
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
log_buffer integer 5242880
SQL> show parameter shared_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
shared_pool_size big integer 4G
SQL> show parameter large_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
large_pool_size big integer 128M
SQL>
SQL> alter system flush buffer_cache;
System altered.
SQL> alter system set db_cache_size=2500M scope=both sid='stg4cus1x02';
System altered.
SQL> alter system flush shared_pool;
System altered.
SQL> alter system set shared_pool_size=2500M scope=both sid='stg4cus1x02';
System altered.
SQL> alter system set sga_target=6000M sid='stg4cus1x02';
System altered.
SQL> alter system set sga_max_size=6200M sid='stg4cus1x02' scope=spfile;
System altered.
SQL> startup force;
ORACLE instance started.
Total System Global Area 6480490496 bytes
Fixed Size 2265112 bytes
Variable Size 3254783976 bytes
Database Buffers 3204448256 bytes
Redo Buffers 18993152 bytes
Database mounted.
Database opened.
Total System Global Area 6480490496 bytes
Fixed Size 2265112 bytes
Variable Size 3254783976 bytes
Database Buffers 3204448256 bytes
Redo Buffers 18993152 bytes
Database mounted.
Database opened.
SQL>
SQL>
SQL>
SQL> SHOW PARAMETER SGA
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
lock_sga boolean FALSE
pre_page_sga boolean FALSE
sga_max_size big integer 6208M
sga_target big integer 6016M
SQL> show parameter db_cache_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_cache_size big integer 2528M
SQL> show parameter shared_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
shared_pool_size big integer 2528M
SQL> show parameter large_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
large_pool_size big integer 128M
SQL> show parameter log_buffer
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
log_buffer integer 5242880
SQL>
Fixed Size 2265112 bytes
Variable Size 3254783976 bytes
Database Buffers 3204448256 bytes
Redo Buffers 18993152 bytes
Database mounted.
Database opened.
SQL>
SQL>
SQL>
SQL> SHOW PARAMETER SGA
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
lock_sga boolean FALSE
pre_page_sga boolean FALSE
sga_max_size big integer 6208M
sga_target big integer 6016M
SQL> show parameter db_cache_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_cache_size big integer 2528M
SQL> show parameter shared_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
shared_pool_size big integer 2528M
SQL> show parameter large_pool_size
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
large_pool_size big integer 128M
SQL> show parameter log_buffer
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
log_buffer integer 5242880
SQL>
http://www.akadia.com/services/ora_asm_multiple_block_sizes.html
we are not able to down size the sga max size and sga target from 35G to 15G. DB bounce is not having any change in thse values
ReplyDelete