修改oracle数据库SGA和PGA大小

您所在的位置:网站首页 oracle重启数据库实例 修改oracle数据库SGA和PGA大小

修改oracle数据库SGA和PGA大小

2023-04-27 03:44| 来源: 网络整理| 查看: 265

SGA的大小:一般物理内存20%用作操作系统保留,其他80%用于数据库。SGA普通数据库可以分配40%-60%之间,PGA可以分配20%-40%之间。先用root配置内核参数:

vi /etc/sysctl.conf fs.file-max = 6815744 kernel.sem = 250 32000 100 128 kernel.shmall = 1073741824 kernel.shmmax = 4398046511104 kernel.panic)on_oops = 1 net.core.rmem_default = 262144 net.core.rmem_max = 4194304 net.core.wmem_default = 262144 net.core.wmem_max = 1048576 net.ipv4.conf.all.rp_filter = 2 net.ipv4.conf.default.rp_filter = 2 fs.aio-max-nr = 1048576 net.ipv4.ip_local_port_range = 9000 65500 /sbin/sysctl -p

调整数据库:1、以dba身份登录并查看SGA信息:

SQL>show parameter sga;

查看PGA信息:

SQL>show parameter pga;

2、修改sga_target

SQL>alter system set sga_target=436M;

3、修改sga_max_size

SQL> alter system set sga_max_size=436M scope=spfile; SQL> alter system set sga_target=436M scope=spfile;

4、重启数据库使其生效:

SQL>shutdown immediate;

注意,重启前一定先完成上述两部操作,且sga_target不得大于sga_max_size,一般保持两者相等,否则可能导致数据库无法启动。

SQL>startup

5、查看SGA是否生效:

SQL>show parameter sga NAME TYPE VALUE ------------------------------------ ----------- ----- lock_sga boolean FALSE pre_page_sga boolean FALSE sga_max_size big integer 436M sga_target big integer 436M

oracle的内存架构:Oracle的内存,从总体上讲,可以分为两大块:共享部分(主要是SGA)和进程独享部分(主要是PGA和UGA)。而这两部分内存里面,根据功能不同,还分为不同内存池(Pool)和内存区(Area),下面就是Oracle内存构成框架图:SGA.png

SGA_TARGET的限制,它的大小是不能超过SGA_MAX_SIZE的大小的。

配置PGA自动管理

直接在线修改。 SQL> alter system set workarea_size_policy=auto scope=both; System altered. SQL> alter system set pga_aggregate_target=512m scope=both; System altered. SQL> show parameter workarea NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ workarea_size_policy string AUTO --这个设置成AUTO SQL> show parameter pga NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ pga_aggregate_target big integer 536870912

监控自动PGA内存管理的性能:

V$PGASTAT:这个视图给出了一个实例级别的PGA内存使用和自动分配的统计。 SQL> set lines 256 SQL> set pages 42 SQL> SELECT * FROM V$PGASTAT; NAME VALUE UNIT ---------------------------------------------------------------- ---------- ------------ aggregate PGA target parameter 536870912 bytes --当前PGA_AGGREGATE_TARGET的值 aggregate PGA auto target 477379584 bytes --当前可用于自动分配了的PGA大小,应该比PGA_AGGREGATE_TARGET 小 global memory bound 26843136 bytes --自动模式下工作区域的最大大小,Oracle根据工作负载自动调整。 total PGA inuse 6448128 bytes total PGA allocated 11598848 bytes --PGA的最大分配 maximum PGA allocated 166175744 bytes total freeable PGA memory 393216 bytes --PGA的最大空闲大小 PGA memory freed back to OS 69074944 bytes total PGA used for auto workareas 0 bytes --PGA分配给auto workareas的大小 maximum PGA used for auto workareas 1049600 bytes total PGA used for manual workareas 0 bytes maximum PGA used for manual workareas 530432 bytes over allocation count 1118 --实例启动后,发生的分配次数,如果这个值大于0,就要考虑增加pga的值 bytes processed 114895872 bytes extra bytes read/written 4608000 bytes cache hit percentage 96.14 percent --命中率 16 rows selected. --V$PGA_TARGET_ADVICE SQL> SELECT round(PGA_TARGET_FOR_ESTIMATE/1024/1024) target_mb, ESTD_PGA_CACHE_HIT_PERCENTAGE cache_hit_perc, ESTD_OVERALLOC_COUNT FROM v$pga_target_advice; The output of this query might look like the following: TARGET_MB CACHE_HIT_PERC ESTD_OVERALLOC_COUNT ---------- -------------- -------------------- 63 23 367 125 24 30 250 30 3 375 39 0 500 58 0 600 59 0 700 59 0 800 60 0 900 60 0 1000 61 0 1500 67 0 2000 76 0 3000 83 0 4000 85 0

可以看出当TARGET_MB 为375M是ESTD_OVERALLOC_COUNT=0,所以可以将PGA_AGGREGATE_TARGET设置成375M。

附:oracle SGA与PGA区别:SGA:是用于存储数据库信息的内存区,该信息为数据库进程所共享。它包含Oracle 服务器的数据和控制信息,它是在Oracle服务器所驻留的计算机的实际内存中得以分配,如果实际内存不够再往虚拟内存中写。PGA:包含单个服务器进程或单个后台进程的数据和控制信息,与几个进程共享的SGA 正相反,PGA 是只被一个进程使用的区域,PGA 在创建进程时分配,在终止进程时回收。

内存结构=SGA(系统全局区)+PGA(程序全局区) 我们重点就是设置SGA,理论上SGA可占OS系统物理内存的1/2——1/3 原则:SGA+PGA+OS使用内存


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3