Oracle數(shù)據(jù)庫查看與修改內(nèi)存配置的方法
Oracle內(nèi)存管理模式
Oracle數(shù)據(jù)庫的內(nèi)存管理模式從自動管理化程度由高到低依次可以分為:
- 自動內(nèi)存管理:完全由Oracle自動管理內(nèi)存分配。DBA只需設(shè)置
MEMORY_TARGET
(以及可選初始化參數(shù)MEMORY_MAX_TARGET
),Oracle就會在SGA和PGA之間自動分配內(nèi)存。 - 自動共享內(nèi)存管理:DBA只需設(shè)置
SGA_TARGET
和PGA_AGGREGATE_TARGET
兩個初始化參數(shù)。Oracle會分別在SGA和PGA中自動分配各組件的內(nèi)存。 - 手動內(nèi)存管理:由DBA為SGA和PGA中的所有組件逐一手動分配內(nèi)存。
在自動共享內(nèi)存管理模式下,還可以手動為SGA中的某些重要組件指定最小的內(nèi)存分配值,例如Shared Pool和Buffer Cache。
查看Oracle內(nèi)存分配
檢查各內(nèi)存參數(shù)的TARGET配置:
SQL> show parameter target NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ memory_max_target big integer 0 memory_target big integer 0 pga_aggregate_target big integer 1561M sga_target big integer 4688M
其中,memory_target
和memory_max_target
都為0,并且sga_target
和pga_aggregate_target
不為0,表示當(dāng)前數(shù)據(jù)庫使用的是自動共享內(nèi)存管理模式。
檢查SGA和PGA相關(guān)參數(shù)的配置:
SQL> show parameter sga NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ sga_max_size big integer 4688M sga_min_size big integer 0 sga_target big integer 4688M SQL> show parameter pga NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ pga_aggregate_limit big integer 3122M pga_aggregate_target big integer 1561M
查看SGA中各組件的內(nèi)存使用情況:
SQL> select * from v$sgainfo; NAME BYTES RESIZEABLE CON_ID -------------------------------- ---------- ---------- ---------- Fixed SGA Size 8906552 No 0 Redo Buffers 7868416 No 0 Buffer Cache Size 3992977408 Yes 0 In-Memory Area Size 0 No 0 Shared Pool Size 872415232 Yes 0 Large Pool Size 33554432 Yes 0 Java Pool Size 0 Yes 0 Streams Pool Size 0 Yes 0 Shared IO Pool Size 134217728 Yes 0 Data Transfer Cache Size 0 Yes 0 Granule Size 16777216 No 0 NAME BYTES RESIZEABLE CON_ID -------------------------------- ---------- ---------- ---------- Maximum SGA Size 4915722040 No 0 Startup overhead in Shared Pool 405891224 No 0 Free SGA Memory Available 0 0 14 rows selected.
其中,Buffer Cache Size和Shared Pool Size是需要重點關(guān)注的內(nèi)容。
修改Oracle內(nèi)存分配
如果我們升級了服務(wù)器物理內(nèi)存配置,就需要對Oracle的內(nèi)存參數(shù)進行修改。
在自動共享內(nèi)存管理模式下,一般按照如下原則配置內(nèi)存:
SGA_TARGET
一般配置為物理內(nèi)存的30%到70%之間;PGA_AGGREGATE_TARGET
一般配置為物理內(nèi)存的5%到25%之間;SGA_TARGET
和PGA_AGGREGATE_TARGET
之和不要超過物理內(nèi)存的80%;- Buffer Cache Size一般配置為
SGA_TARGET
的 20% 左右; - Shared Pool Size一般配置為
SGA_TARGET
的 10% 左右。
修改數(shù)據(jù)庫內(nèi)存配置:
--備份參數(shù)文件 create pfile='/home/oracle/pfile.ora' from spfile; --禁用自動內(nèi)存管理 alter system set memory_target=0M scope=spfile; --設(shè)置SGA_TARGET alter system set sga_max_size=9G scope=spfile; alter system set sga_target=9G scope=spfile; --設(shè)置Buffer cache、共享池、Java池的最小值 alter system set db_cache_size=2G scope=spfile; alter system set shared_pool_size=1G scope=spfile; alter system set java_pool_size=128m scope=spfile; --設(shè)置PGA_AGGREGATE_TARGET alter system set pga_aggregate_target=1G scope=spfile;
然后重啟數(shù)據(jù)庫即可生效。
SQL> show parameter sga_target NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ sga_target big integer 9G SQL> show parameter pga NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ pga_aggregate_limit big integer 3000M pga_aggregate_target big integer 1G SQL> show parameter db_cache_size NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ db_cache_size big integer 2G SQL> show parameter shared_pool_size NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ shared_pool_size big integer 1G SQL> show parameter java_pool_size NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ java_pool_size big integer 128M
需要注意的是,服務(wù)器物理內(nèi)存變化通常還涉及內(nèi)核參數(shù)kernel.shmall
和kernel.shmmax
的調(diào)優(yōu)。如果數(shù)據(jù)庫使用了大頁,還需要調(diào)優(yōu)操作系統(tǒng)的大頁配置。
# 查看是否開啟大頁 SQL> show parameter use_large_pages # 查看操作系統(tǒng)大頁配置 cat /proc/meminfo | grep HugePage cat /proc/meminfo | grep Hugepagesize
總結(jié)
到此這篇關(guān)于Oracle數(shù)據(jù)庫查看與修改內(nèi)存配置的文章就介紹到這了,更多相關(guān)Oracle查看修改內(nèi)存配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Oracle庫恢復(fù)刪除數(shù)據(jù)的方法小結(jié)
誤刪?Oracle?庫中的數(shù)據(jù),在不考慮全庫備份和利用歸檔日志情況,如何恢復(fù)數(shù)據(jù)呢,這篇文章將給大家介紹幾種方法恢復(fù)數(shù)據(jù),文章通過代碼示例給大家介紹的非常詳細,需要的朋友可以參考下2023-12-12數(shù)據(jù)庫查詢排序使用隨機排序結(jié)果示例(Oracle/MySQL/MS SQL Server)
數(shù)據(jù)庫查詢排序使用隨機排序結(jié)果示例,這里提供了Oracle/MySQL/MS SQL Server三種數(shù)據(jù)庫的示例2013-12-12oracle 數(shù)據(jù)庫隔離級別學(xué)習(xí)
這篇文章主要介紹了oracle數(shù)據(jù)庫的隔離級別相關(guān)的知識,數(shù)據(jù)庫操作的隔離級別,有需要的朋友可以參考下2014-05-05Oracle導(dǎo)dmp出現(xiàn)文件ORA-12154: TNS: 無法解析指定的連接標(biāo)識符問題的解決方案
這篇文章主要介紹了Oracle導(dǎo)dmp出現(xiàn)文件ORA-12154: TNS: 無法解析指定的連接標(biāo)識符問題的解決方案,需要的朋友可以參考下2017-03-03JDBC Oracle執(zhí)行executeUpdate卡死問題的解決方案
今天小編就為大家分享一篇關(guān)于JDBC Oracle執(zhí)行executeUpdate卡死問題的解決方案,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12oracle實現(xiàn)一對多數(shù)據(jù)分頁查詢篩選示例代碼
這篇文章主要給大家介紹了關(guān)于oracle實現(xiàn)一對多數(shù)據(jù)分頁查詢篩選的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11