ORA-04031錯誤的處理

westzq1984發表於2009-04-09

4031我兩年遇到了不下5次,現在總結下下

4031錯誤是SHARED_POOL很容易產生的錯誤,對於SHARED_POOL的原因一般有3類:
  BUG
  SHARED_POOL太小
  SHARED_POOL有太多的碎片
對於LARGE POOL,JAVA POOL,一般是由於設定的太小導致到

BUG可以從Doc ID:  396940.1 中查詢
SHARED_POOL太小,可以通過監控v$sgastat檢視free memory是否過少,或者在04031發生後生成的DUMP中也可以檢視到
SHARED_POOL有太多的碎片,這個可以通過x$ksmsp來分析,或者是04031發生後的DUMP

如何來減少04031錯誤了
1.10G的SGA自動管理
2.定期flush SHARED_POOL
3.不要設定過高的session_cache_cursor
4.使用繫結變數
5.當沒有使用繫結變數而且cursor_sharing=similar時,一定不要收集直方圖
6.加大SHARED_POOL_RESERVED_MIN_ALLOC的空間,保留空間也可能發生04031,具體診斷是監控v$shared_pool_reserved
7.把一些大的物件PIN到SHARED_POOL中

對於碎片造成的04031,一般的原因是沒有使用繫結變數的SQL和大量的硬解析
查詢的方法一般有
  v$sqlarea中基本相同的SQL
  v$sqlarea中version_count異常高的SQL
  通過v$open_cursor和v$sqlarea查詢當前佔用記憶體高的SESSION,在獲得該SESSION的SQL分析(還方法不適合於存在version_count異常高的情況)
  DUMP library_cache 來分析SQL硬解析的SQL

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

相關文章