WEB开发网
开发学院数据库Oracle Oracle9i的动态SGA特性探索 阅读

Oracle9i的动态SGA特性探索

 2006-08-05 11:58:56 来源:WEB开发网   
核心提示: Aggregate PGA auto target -该列给出了可用于Oracle9i连接的全部内存,我们已经提过,Oracle9i的动态SGA特性探索(6),这个值是由PGA_AGGREGATE_TARGET设置的,Global memory bound -该统计表示work area的

Aggregate PGA auto target -该列给出了可用于Oracle9i连接的全部内存。我们已经提过,这个值是由PGA_AGGREGATE_TARGET设置的。

Global memory bound -该统计表示work area的最大值,Oracle建议在该统计值下降到1M时,你应该增加PGA_AGGREGATE_TARGET的值。

Total PGA allocated - 这个统计显示了数据库中全部PGA内存使用的高水位线。当使用增加时,你应该看到这个值接近PGA_AGGREGATE_TARGET的值。

Total PGA used for auto workareas - 这个统计监视内存的使用或者全部运行在自动内存模式中的全部连接。要记住的是,并不是全部的内部进程使用自动内存特性。例如,Java和PL/SQL 将分配内存,但是这部分将不会统计到这个值中。因此我们可使用整体PGA的值来减去该值,以得到连接和Java and PL/SQL使用的内存。

Estimated PGA memory for optimal/one-pass - 该统计估计optimal模式下执行全部的连接任务所需要的内存。要记住的是,如果Oracle9i遇到内存不足时,它就会调用multi-pass操作。这个统计对于监视Oracle9i中的内存使用是非常重要的,大多数的Oracle DBA将会增加PGA_AGGREGATE_TARGET到这个值。

现在我们已经了解了这个概念,以下就让我们来看一下自动重新配置SGA有哪些方法。

总述

在一个UNIX环境中,在处理需求改变时通过定时任务来修改内存配置是非常简单的。例如,许多Oracle数据库在一般的工作时间以OLTP模式运作,在晚上的时候则运行对内存需求很大的批量报告。

我们知道在一个OLTP数据库中应该将DB_CACHE_SIZE设置为一个较大的值,而在需求内存很大的批量任务中则需要给PGA_AGGREGATE_TARGET分配额外的内存。

以下的UNIX脚本可以用来重新设置OLTP和DSS的SGA值而无需将实例停下来。在这个例子中,我们假定有一个孤立的带有8GB内存的的Oracle服务器。我们还假定保留20%的内存供UNIX使用,而剩下的6GB内存则用作Oracle和Oracle连接。这些脚本是在HP/UX或者Solaris中使用的,并且接受$ORACLE_SID作为一个参数。

DSS_CONFIG.KSH脚本将在每晚的6:00 p.m运行,以重新设置Oracle在晚上运行对内存需求很大的批量任务。

dss_config.ksh
#!/bin/ksh
# First, we must set the environment . . . .
ORACLE_SID=$1
export ORACLE_SID
ORACLE_HOME=`cat /etc/oratab|grep ^$ORACLE_SID:|cut -f2 -d':'`
#ORACLE_HOME=`cat /var/opt/oracle/oratab|grep ^$ORACLE_SID:|cut -f2 -d':'`
export ORACLE_HOME
PATH=$ORACLE_HOME/bin:$PATH
export PATH
$ORACLE_HOME/bin/sqlplus -s /nologin<
connect system/manager as sysdba;
ALTER SYSTEM set db_cache_size=1500m;
ALTER SYSTEM set shared_pool_size=500m;
ALTER SYSTEM set pga_aggregate_target=400m;
exit
!

现在我们已经知道了一个常见的方式来修改Oracle的配置,我们也很容易地看到可以很简单地开发一个技术来连续地监控Oracle的处理需求,并且根据现有的数据库需求来使用ALTER SYSTEM作修改。

结论

虽然Oracle9i中的内存管理仍然需要很多的手工操作,不过大部分的Oracle管理员可以使用工具来连续地监控Oracle SGA中的内存使用,并且可以根据Oracle instance中现在的使用情况来自动地重新分配内存。这样就可以令Oracle 管理员根据系统的变化来灵活地重新设置他们的系统。

上一页  1 2 3 4 5 6 

Tags:Oraclei 动态 SGA

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接