修改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

 

相關文章


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM