Oracle SGA 自动管理特性(sga_target参数)

    最近有网友对Oracle SGA内存自动管理特性不是很清楚,可能是由于当时翻译的 Oracle 10g SGA 的自动化管理 比较生涩,下面依旧是针对这个问题给出在Oracle 10g环境中描述,并给出示例以便更好的理解。

 

1、相关参数描述
a、参数SHARED_POOL_SIZE
SHARED_POOL_SIZE = integer [K | M | G]

Default value
   If SGA_TARGET is set: If the parameter is not specified, then the default is 0 (internally determined by the Oracle Database).
   If the parameter is specified, then the user-specified value indicates a minimum value for the memory pool.
   If SGA_TARGET is not set (32-bit platforms): 32 M, rounded up to the nearest granule size.
   If SGA_TARGET is not set (64-bit platforms): 84 M, rounded up to the nearest granule size.
Range of values Minimum: 
   the granule size
Maximum:
   operating system-dependent
 
b、参数SGA_TARGET
SGA_TARGET = integer [K | M | G]
Default value 0 (SGA autotuning is disabled)

SGA_TARGET specifies the total size of all SGA components.
If SGA_TARGET is specified, then the following memory pools are automatically sized:
    Buffer cache (DB_CACHE_SIZE)
    Shared pool (SHARED_POOL_SIZE)
    Large pool (LARGE_POOL_SIZE)
    Java pool (JAVA_POOL_SIZE)
    Streams pool (STREAMS_POOL_SIZE)

If these automatically tuned memory pools are set to non-zero values, then those values are used as minimum levels by Automatic
Shared Memory Management. You would set minimum values if an application component needs a minimum amount of memory to function properly.

The following pools are manually sized components and are not affected by Automatic Shared Memory Management:
  Log buffer
  Other buffer caches, such as KEEP, RECYCLE, and other block sizes
  Fixed SGA and other internal allocations

The memory allocated to these pools is deducted from the total available for SGA_TARGET when Automatic Shared Memory Management
computes the values of the automatically tuned memory pools.

 

2、参数sga_target为零值的情形

--#编辑一个临时的参数文件,并设置sga_target=0,以及设定几个pool池的size,db_cache_size,如下
robin@SZDB:/u02/database/SYBO2SZ> grep size SYBO2SZ.ora.tmp   
*.db_block_size=8192
*.db_cache_size=285212672
*.db_recovery_file_dest_size=1G
*.java_pool_size=4194304
*.large_pool_size=4194304
*.shared_pool_size=293601280
*.streams_pool_size=4194304
robin@SZDB:/u02/database/SYBO2SZ> grep target SYBO2SZ.ora.tmp
*.pga_aggregate_target=199229440
*.sga_target=0

--#使用临时的参数文件启动数据库
robin@SZDB:/u02/database/SYBO2SZ> sqlplus / as sysdba
idle> startup pfile=/u02/database/SYBO2SZ/SYBO2SZ.ora.tmp
ORACLE instance started.
---可以看到此时sga_target为0
idle> show parameter sga_tar

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
sga_target                           big integer 0

-->查看此时内存分配的情况
idle> SELECT name, VALUE
  2    FROM v$parameter
  3   WHERE name IN
  4            ('shared_pool_size',
  5             'java_pool_size',
  6             'streams_pool_size',
  7             'log_buffer',
  8             'db_cache_size',
  9             'db_2k_cache_size',
 10             'db_4k_cache_size',
 11             'db_8k_cache_size',
 12             'db_16k_cache_size',
 13             'db_32k_cache_size',
 14             'db_keep_cache_size',
 15             'db_recycle_cache_size',
 16             'large_pool_size');

NAME                           VALUE
------------------------------ --------------------
shared_pool_size               293601280
large_pool_size                4194304
java_pool_size                 4194304
streams_pool_size              4194304
db_cache_size                  285212672
db_2k_cache_size               0
db_4k_cache_size               0
db_8k_cache_size               0
db_16k_cache_size              0
db_32k_cache_size              0
db_keep_cache_size             0
db_recycle_cache_size          0
log_buffer                     6120448

13 rows selected.

-- Author :Robinson
-- Blog   :http://blog.csdn.net/robinson_0612

--使用临时的pfile来创建spfile
idle>  create spfile from pfile='/u02/database/SYBO2SZ/SYBO2SZ.ora.tmp';

File created.

3、参数sga_target非零值的情形

--重启db
idle> startup force;
ORACLE instance started.

idle> select distinct isspecified from v$spparameter;

ISSPEC
------
TRUE    -->为true表名此时使用了spfile启动数据库
FALSE

--此时sga_max的值为572m
idle> show parameter sga_max

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
sga_max_size                         big integer 572M

--修改sga_target到非零值
idle> alter system set sga_target=572m;      

System altered.

--此时sga_target变成了576m,这个是由于分配粒度和当前已分配内存之和造成的,自动向上取整
idle> show parameter sga_target

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
sga_target                           big integer 576M

--参数文件指定的值分配的总大小为564m
idle> select (285212672+4194304+4194304+293601280+4194304)/1024/1024 from dual;

(285212672+4194304+4194304+293601280+4194304)/1024/1024
-------------------------------------------------------
                                                    564
                                                    
--来看一下内存的分配粒度,此时为4mb
idle> @mem_granule

NAME                                VALUE                          DESCBTION
----------------------------------- ------------------------------ ----------------------------
_ksmg_granule_size                  4194304                        granule size in bytes
_ksmg_granule_locking_status        1                              granule locking status

--值572m也是4的整数倍,这个应该是有一部分固定或其他方面内存耗用所致当前被分配了576m
--如果参数文件中总大小缩小的话,我们可以指定sga_target<=sga_max_size
idle> select 576/4 from dual;

     576/4
----------
       144
       
--从spfile生成pfile来观察sga_target非零值发生了什么变化
idle> create pfile='/tmp/tmp.ora' from spfile;

File created.

--可以看到增加了以dbname开头的且带下划线的和sga_target内存分配相关的项
idle> ho grep size /tmp/tmp.ora
SYBO2SZ.__db_cache_size=285212672
SYBO2SZ.__java_pool_size=4194304
SYBO2SZ.__large_pool_size=4194304
SYBO2SZ.__shared_pool_size=297795584
SYBO2SZ.__streams_pool_size=4194304
*.db_block_size=8192
*.db_cache_size=285212672
*.db_recovery_file_dest_size=1G
*.java_pool_size=4194304
*.large_pool_size=4194304
*.shared_pool_size=293601280
*.streams_pool_size=4194304

--/tmp/tmp.ora文件中的sga_target变成了603979776=576m
idle> ho grep sga_target /tmp/tmp.ora
*.sga_target=603979776

--下面编辑/tmp/tmp.ora,移除原来的有关内存的配值,用带下划线的值来启动数据库
idle> vi /tmp/tmp.ora
idle> ho grep size /tmp/tmp.ora
SYBO2SZ.__db_cache_size=285212672
SYBO2SZ.__java_pool_size=4194304
SYBO2SZ.__large_pool_size=4194304
SYBO2SZ.__shared_pool_size=297795584
SYBO2SZ.__streams_pool_size=4194304
*.db_block_size=8192
#*.db_cache_size=285212672
*.db_recovery_file_dest_size=1G
#*.java_pool_size=4194304
#*.large_pool_size=4194304
#*.shared_pool_size=293601280
#*.streams_pool_size=4194304

--首先关闭数据库
idle> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.

--使用临时的pfile启动
idle> startup pfile=/tmp/tmp.ora
ORACLE instance started.

--下面的查询可以看到所有和sga_target相关的内存分配全部变成了0
idle> SELECT name, VALUE
  2    FROM v$parameter
  3   WHERE name IN
  4            ('shared_pool_size',
  5             'java_pool_size',
  6             'streams_pool_size',
  7             'log_buffer',
  8             'db_cache_size',
  9             'db_2k_cache_size',
 10             'db_4k_cache_size',
 11             'db_8k_cache_size',
 12             'db_16k_cache_size',
 13             'db_32k_cache_size',
 14             'db_keep_cache_size',
 15             'db_recycle_cache_size',
 16             'large_pool_size');

NAME                                VALUE
----------------------------------- ------------------------------
shared_pool_size                    0
large_pool_size                     0
java_pool_size                      0
streams_pool_size                   0
db_cache_size                       0
db_2k_cache_size                    0
db_4k_cache_size                    0
db_8k_cache_size                    0
db_16k_cache_size                   0
db_32k_cache_size                   0
db_keep_cache_size                  0
db_recycle_cache_size               0
log_buffer                          6120448

13 rows selected.

--此时sga_max_size也变成了576m,这是因为sga_target必须小于等于sga_max_size
idle> show parameter sga_max

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
sga_max_size                         big integer 576M

4、小结
a、当设置sga_target为非零值时下列参数受到sga_targe的控制,但其总值不超过sga_target。
   Buffer cache (DB_CACHE_SIZE)
   Shared pool (SHARED_POOL_SIZE)
   Large pool (LARGE_POOL_SIZE)
   Java pool (JAVA_POOL_SIZE)
   Streams pool (STREAMS_POOL_SIZE)
b、非零值的sga_target时,几个参数之间的大小可以动态分配,且根据需要来动态调整各个部分的大小。
c、如果在sga_target非零值时,也设定了DB_CACHE_SIZE等上述几个参数,则sga_targe分配不小于所设置的值作为初始值。
d、当设置sga_target为零值时,SGA相关参数内存的分配由参数控制,且无法根据系统状况实施动态调整大小。
f、Oracle 10g之后建议将SGA的内存管理设置为由sga_target动态管理。

 

更多参考

PL/SQL --> 游标

PL/SQL --> 隐式游标(SQL%FOUND)

批量SQL之 FORALL 语句

批量SQL之 BULK COLLECT 子句

PL/SQL 集合的初始化与赋值

PL/SQL 联合数组与嵌套表
PL/SQL 变长数组
PL/SQL --> PL/SQL记录

SQL tuning 步骤

高效SQL语句必杀技

父游标、子游标及共享游标

绑定变量及其优缺点

dbms_xplan之display_cursor函数的使用

dbms_xplan之display函数的使用

执行计划中各字段各模块描述

使用 EXPLAIN PLAN 获取SQL语句执行计划

Oracle ROWID

NULL 值与索引(一)

NULL 值与索引(二)

启用 AUTOTRACE 功能

函数使得索引列失效

Oracle 绑定变量窥探

Oracle 自适应共享游标

Oracle 表空间与数据文件
Oracle 密码文件
Oracle 参数文件
Oracle 联机重做日志文件(ONLINE LOG FILE)
Oracle 控制文件(CONTROLFILE)
Oracle 归档日志
Oracle 回滚(ROLLBACK)和撤销(UNDO)
Oracle 数据库实例启动关闭过程
Oracle 10g SGA 的自动化管理
Oracle 实例和Oracle数据库(Oracle体系结构) 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用\[1\],SGA_TARGETOracle数据库中的一个参数,用于指定系统全局区(SGA)的目标大小。如果在查询SGA_TARGET时遇到ORA-00821错误,表示指定的值太小,需要至少为5504M。要查询SGA_TARGET的值,可以通过查看Oracle安装目录下的参数文件来获取。参数文件的路径为$ORACLE_HOME/dbs,文件名格式为init+数据库实例名+.ora。可以使用命令"echo $ORACLE_HOME"来查看Oracle安装目录。如果参数文件丢失,可以参考Linux下Oracle数据库参数文件丢失解决方法。通过使用vim编辑器打开参数文件,可以查看其中的值。根据引用\[2\]和\[3\],可以使用ALTER SYSTEM SET语句来修改SGA_MAX_SIZE参数的值。例如,可以使用以下命令将SGA_MAX_SIZE设置为6442450944: ALTER SYSTEM SET sga_max_size = 6442450944 COMMENT='internally adjusted' SCOPE=SPFILE SID='INTOPAY'; 请注意,修改参数后需要重启数据库才能生效。 #### 引用[.reference_title] - *1* [Oracle 数据库修改配置文件sga_target参数的值,sga_target值太小导致数据库服务起不来问题解决,调大sga_...](https://blog.csdn.net/qq_38161040/article/details/118801809)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Oracle 11g sga_target 参数设置](https://blog.csdn.net/weixin_39643679/article/details/116418724)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值