• 修改oracle数据库SGA和PGA大小


    修改oracle数据库SGA和PGA大小

    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使用内存<总物理RAM
    SGA=((db_block_buffers*blocksize)+(shared_pool_size+large_pool_size+java_pool_size+log_buffers)+1MB
    1、SGA系统全局区.(包括以下五个区)
    A、数据缓冲区:(db_block_buffers)存储由磁盘数据文件读入的数据。
    大小: db_block_buffers*db_block_size
    Oracle9i设置数据缓冲区为:Db_cache_size
    原则:SGA中主要设置对象,一般为可用内存40%。
    B、共享池:(shared_pool_size):数据字典,sql缓冲,pl/sql语法分析.加大可提速度。
    原则:SGA中主要设置对象,一般为可用内存10%
    C、日志缓冲区:(log_buffer)存储数据库的修改信息.
    原则:128K ---- 1M 之间,不应该太大
    D 、JAVA池(Java_pool_size)主要用于JAVA语言的开发.
    原则:若不使用java,原则上不能小于20M,给30M通常就够了
    E、 大池(Large_pool_size) 如果不设置MTS,主要用于数据库备份恢复管理器RMAN。
    原则:若不使用MTS,5---- 10M 之间,不应该太大
    SGA=. db_block_buffers*db_block_size+ shared_pool_size+ log_buffer+Java_pool+size+large_pool_size

    相关文章

  • 相关阅读:
    java lang(Class)
    java.lang(StringBuffer)
    java.lang(String)
    java.lang包【Object类】
    IIS发布错误
    ASP.NET MVC之视图生成URL
    JQuery性能优化
    ERP联系记录管理(十七)
    C# virtual和abstract的
    ERP联系人查询和修改(十六)
  • 原文地址:https://www.cnblogs.com/yaoyangding/p/15248337.html
Copyright © 2020-2023  润新知