WINDOWS平臺上擴充套件SGA

jss001發表於2009-03-01
針對32bit的Windows。Windows2000上不能利用超過4G的記憶體,一般是2G的記憶體保留給程式,2G記憶體保留給核心的。在Windows2000 Advanced Server上可以分配3G給程式,1G留給核心的。
1. 如果機器的記憶體在4G以下,可以使用Physical Address Extensions(PAE)或者是Address Windowing Extensions(AWE)進行擴充套件,如果機器記憶體大於4GB就只能使用AWE進行擴充套件了。
AWE支援以下的Windows作業系統:
Windows 2000 Datacenter Server
Windows 2000 Advanced Server
Windows 2003 Datacenter Edition(32bit)
Windows 2003 Enterprise Edition(32bit)
AWE不支援以下的Windows作業系統:
Windows 2000 Server(Standard)
Windows2000 Professional
Windows XP Home Edition
Windows XP Professional
Windows 2003 Standard Edition
Windows 2003 Web Edition
AWE支援的
資料庫的版本:
Oracle 8.1.6.X
Oracle 8.1.7.X
Oracle 9.2.X
AWE不支援Oracle9.0.1.X
在標準版的Oracle9.2.0.1上,如果你設定了use_indirect_data_buffers=true,啟動就會報錯:
ORA-439-feature not enabled:very large memory.
這個是標準版的Oracle的9.2.0.1的一個bug(#2520796),在Oracle9.2.0.2中解決了。
2. 在作業系統上啟動AWE
AWE在作業系統上可以透過在boot.ini檔案中加/PAE切換啟用。
例如:
multi(0)disk(0)rdisk(0)partition(1)WINNT="Microsoft Windows 2000 Advanced Server" /PAE
也可以同時使用/PAE和/3G在同一臺機器上,例如:
multi(0)disk(0)rdisk(0)partition(1)WINNT="Microsoft Windows 2000 Advanced Server" /3GB /PAE
但是同時使用記憶體最到能夠支援到16G,如果用使用16G以上的記憶體,則必須選擇其中的一種使用了。
3. 在Oracle上啟用AWE
首先要在啟動的引數檔案中設定引數
USE_INDIRECT_DATA_BUFFERS=TRUE
如果設定了這個引數,對於Oracle9.2.0的版本則不能再使用DB_CACHE_SIZE引數了,只能使用DB_BLOCK_BUFFERS引數。
擴充套件的記憶體只能增加到BUFFER CACHE中去使用,因此只能增大DB_BLOCK_BUFFERS這個引數去擴充套件SGA區。
4. AWE_WINDOW_MEMORY實現故障解決
在Oracle8.1.7版本以下啟動
的時候不用設定AWE_WINDOW_MEMORY的最小值,而在Oracle9.2.0的版本中則強制要設定AWE_WINDOW_MEMORY的最小值,這個最小值在Oracle8.1.7中透過DB_BLOCK_LRU_LATCHES引數設定,在Oracle9.2.0中則透過_DB_BLOCK_LRU_LATCHES隱含引數設定,Oracle9.2.0的AWE_WINDOW_MEMORY的最小值由以下的公式計算:
MIN(AWE_WINDOW_MEMORY)=(4096 * DB_BLOCK_SIZE * _DB_BLOCK_LRU_LATCHES)/8
_DB_BLOCK_LRU_LATCHES = (Max buffer pools * SETS_PER_POOL)
Max Buffer Pools是個常量,等於8,SETS_PER_POOL是個變數,它的大小由是否啟用VLM(即設定USE_INDIRECT_DATA_BUFFERS=TRUE引數)決定:
SETS_PER_POOL = 2* CPU_COUNT (啟用 VLM)
SETS_PER_POOL= CPU Count /2 (不啟用VLM)
例如:
CPU's = 16
DB_BLOCK_SIZE = 8192
Total RAM = 16 GB
SETS_PER_POOL = 2 * CPU_COUNT = 32
_DB_BLOCK_LRU_LATCHES = (max buffer Pools * sets_per_pool) = 8*32 = 256 MIN(AWE_WINDOW_MEMORY)=(4096*DB_BLOCK_SIZE*_DB_BLOCK_LRU_LATCHES)/8 =( 4096 * 8192 * 256) / 8 = 1073741824 bytes = 1024 MB
這樣在Windows的登錄檔中的HKLMSoftwareOracleHomex下的AWE_WINDOW_MEMORY值至少是1024M,否則就會提示錯誤:
ORA-27102 out of memory
OSD-00034 Message 34 not found; Product=RDBMS;facility =SOSD
O/S Error: (OS 8) Not enough storage is available to process this command
[@more@]

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

相關文章