修改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_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
最后更新於 2020-11-14 11:49:08 並被添加「sga PGA」標簽,已有 394 位童鞋閱讀過。
本站使用「署名 4.0 國際」創作共享協議,可自由轉載、引用,但需署名作者且注明文章出處