oracle 8i的記憶體引數設定

zhanglincon發表於2009-04-27
ORACLE 8.0.X 版本

SGA=((db_block_buffers * block size)+(shared_pool_size+large_pool_size+log_buffers)+1MB

ORACLE 8.1.X 版本

SGA=((db_block_buffers * block size)+(shared_pool_size+large_pool_size+java_pool_size+log_buffers)+1MB

理論上SGA可佔OS系統實體記憶體的1/2——1/3,我們可以根據需求調整

我推薦SGA=0.45*(OS RAM)

假設伺服器執行ORACLE 8.1.X 版本, OS系統記憶體為2G MEM, db_block_size 是8192 bytes,
除了執行ORACLE資料庫外, 沒有其它的應用程式或伺服器軟體.

這樣SGA合計約為921M ( 0.45*2048M ),

設shared_pool_size 300M (300*1024*1024 bytes)

設database buffer cache 570M (72960*8192 bytes)

initorasid.ora檔案裡具體各引數如下:

shared_pool_size = 314572800
# 300 M

db_block_buffers = 72960
# 570 M

log_buffer = 524288
# 512k (128K*CPU個數)

large_pool_size = 31457280
# 30 M

java_pool_size = 20971520
# 20 M

sort_area_size = 524288
# 512k (65k--2M)

sort_area_retained_size = 524288
# MTS 時 sort_area_retained_size = sort_area_size

SUN Solaris裡/etc/system檔案裡的幾個引數同樣跟記憶體分配有關

ORACLE安裝時預設的設定: 建議修改的設定:
set shmsys:shminfo_shmmax=4294967295
set shmsys:shminfo_shmmin=1
set shmsys:shminfo_shmmni=100
set shmsys:shminfo_shmseg=15
set semsys:seminfo_semmns=200
set semsys:seminfo_semmni=70
set ulimit=3000000
set semsys:seminfo_semmni=315
set semsys:seminfo_semmsl=300
set semsys:seminfo_semmns=630
set semsys:seminfo_semopm=315
set semsys:seminfo_semvmx=32767
set shmsys:shminfo_shmmax=4294967295
set shmsys:shminfo_shmmni=315
set shmsys:shminfo_shmseg=10
set shmsys:shminfo_shmmin=1

其中這些引數的含義

shmmax - 共享記憶體段,建議設大點, 達到最大SGA
shmmin - 最小的共享記憶體段.
shmmni - 共享記憶體標誌符的數量.
shmseg - 一個程式可分配的最大記憶體段數.
shmall - 最大可允許的記憶體數,比SGA還要大.
semmns - 訊號燈,跟ORACLE的PROCESS數有關.
semmsl - 一個訊號燈中最大的訊號燈數.

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/8554499/viewspace-591910/,如需轉載,請註明出處,否則將追究法律責任。

相關文章