Oracle9i 动态SGA,PGA特性探索(5)

来源:asp之家 时间:2009-04-24 12:39:00 


  我们还可以使用V$PGASTAT视图来决定我们的Oracle实例的内存使用。V$PGASTAT视图提供了PGA使用和自动内存管理的实例级摘要统计信息。以下的脚本提供了全部Oracle9i连接的整体内存使用的统计信息。
  以下是一个用来检测Oracle9i中PGA内存使用的简单脚本。
check_pga.sql
column name format a30
column value format 999,999,999
select
name,
value
from
v$pgastat
The output of this query might look like the following:
NAME VALUE
------------------------------------------------------ ----------
aggregate PGA auto target 736,052,224
global memory bound 21,200
total expected memory 141,144
total PGA inuse 22,234,736
total PGA allocated 55,327,872
maximum PGA allocated 23,970,624
total PGA used for auto workareas 262,144
maximum PGA used for auto workareas 7,333,032
total PGA used for manual workareas 0
maximum PGA used for manual workareas 0
estimated PGA memory for optimal 141,395
maximum PGA memory for optimal 500,123,520
estimated PGA memory for one-pass 534,144
maximum PGA memory for one-pass
  在上面的v$pgastat显示中我们可以看到以下的统计。
  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 管理员根据系统的变化来灵活地重新设置他们的系统。

标签:Oracle9i,动态,SGA,PGA
0
投稿

猜你喜欢

  • Python调用C++程序的方法详解

    2023-12-10 12:53:06
  • python plotly画柱状图代码实例

    2023-11-29 13:41:31
  • JavaScript中把数字转换为字符串的程序代码

    2024-05-03 15:59:46
  • Python操作Oracle数据库的简单方法和封装类实例

    2024-01-15 09:34:32
  • Python实现个人微信号自动监控告警的示例

    2023-02-04 20:03:03
  • Python中的XML库4Suite Server的介绍

    2023-08-12 01:26:41
  • SQLServer2014故障转移群集的部署的图文教程

    2024-01-28 23:30:06
  • Python运维开发之psutil库的使用详解

    2023-10-24 14:22:55
  • String与string的区别(注意大小写)

    2023-06-28 22:04:13
  • Python中一般处理中文的几种方法

    2023-10-11 01:45:23
  • Python学习笔记之Zip和Enumerate用法实例分析

    2021-09-03 19:58:50
  • PyQt与pycharm的结合使用教程

    2022-09-08 06:47:05
  • python实现猜数游戏(保存游戏记录)

    2022-08-31 09:39:54
  • vue服务器代理proxyTable配置如何解决跨域

    2024-04-28 09:22:32
  • Python提高运行速度工具之Pandarallel的使用教程

    2021-07-16 20:14:09
  • Redis 的 GeoHash详解

    2024-01-22 12:32:43
  • 全面解析Bootstrap中tooltip、popover的使用方法

    2024-05-21 10:14:19
  • TensorFlow自定义损失函数来预测商品销售量

    2023-01-08 07:01:51
  • Python线性表种的单链表详解

    2022-03-02 07:36:58
  • C#使用ADO.Net部件来访问Access数据库的方法

    2024-01-27 01:45:42
  • asp之家 网络编程 m.aspxhome.com