Oracle數(shù)據(jù)庫(kù)查看與修改內(nèi)存配置的方法
Oracle內(nèi)存管理模式
Oracle數(shù)據(jù)庫(kù)的內(nèi)存管理模式從自動(dòng)管理化程度由高到低依次可以分為:
- 自動(dòng)內(nèi)存管理:完全由Oracle自動(dòng)管理內(nèi)存分配。DBA只需設(shè)置
MEMORY_TARGET
(以及可選初始化參數(shù)MEMORY_MAX_TARGET
),Oracle就會(huì)在SGA和PGA之間自動(dòng)分配內(nèi)存。 - 自動(dòng)共享內(nèi)存管理:DBA只需設(shè)置
SGA_TARGET
和PGA_AGGREGATE_TARGET
兩個(gè)初始化參數(shù)。Oracle會(huì)分別在SGA和PGA中自動(dòng)分配各組件的內(nèi)存。 - 手動(dòng)內(nèi)存管理:由DBA為SGA和PGA中的所有組件逐一手動(dòng)分配內(nèi)存。
在自動(dòng)共享內(nèi)存管理模式下,還可以手動(dòng)為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ù)庫(kù)使用的是自動(dòng)共享內(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是需要重點(diǎn)關(guān)注的內(nèi)容。
修改Oracle內(nèi)存分配
如果我們升級(jí)了服務(wù)器物理內(nèi)存配置,就需要對(duì)Oracle的內(nèi)存參數(shù)進(jìn)行修改。
在自動(dòng)共享內(nèi)存管理模式下,一般按照如下原則配置內(nèi)存:
SGA_TARGET
一般配置為物理內(nèi)存的30%到70%之間;PGA_AGGREGATE_TARGET
一般配置為物理內(nèi)存的5%到25%之間;SGA_TARGET
和PGA_AGGREGATE_TARGET
之和不要超過(guò)物理內(nèi)存的80%;- Buffer Cache Size一般配置為
SGA_TARGET
的 20% 左右; - Shared Pool Size一般配置為
SGA_TARGET
的 10% 左右。
修改數(shù)據(jù)庫(kù)內(nèi)存配置:
--備份參數(shù)文件 create pfile='/home/oracle/pfile.ora' from spfile; --禁用自動(dòng)內(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ù)庫(kù)即可生效。
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ù)庫(kù)使用了大頁(yè),還需要調(diào)優(yōu)操作系統(tǒng)的大頁(yè)配置。
# 查看是否開(kāi)啟大頁(yè) SQL> show parameter use_large_pages # 查看操作系統(tǒng)大頁(yè)配置 cat /proc/meminfo | grep HugePage cat /proc/meminfo | grep Hugepagesize
總結(jié)
到此這篇關(guān)于Oracle數(shù)據(jù)庫(kù)查看與修改內(nèi)存配置的文章就介紹到這了,更多相關(guān)Oracle查看修改內(nèi)存配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Oracle庫(kù)恢復(fù)刪除數(shù)據(jù)的方法小結(jié)
誤刪?Oracle?庫(kù)中的數(shù)據(jù),在不考慮全庫(kù)備份和利用歸檔日志情況,如何恢復(fù)數(shù)據(jù)呢,這篇文章將給大家介紹幾種方法恢復(fù)數(shù)據(jù),文章通過(guò)代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12數(shù)據(jù)庫(kù)查詢排序使用隨機(jī)排序結(jié)果示例(Oracle/MySQL/MS SQL Server)
數(shù)據(jù)庫(kù)查詢排序使用隨機(jī)排序結(jié)果示例,這里提供了Oracle/MySQL/MS SQL Server三種數(shù)據(jù)庫(kù)的示例2013-12-12oracle 數(shù)據(jù)庫(kù)隔離級(jí)別學(xué)習(xí)
這篇文章主要介紹了oracle數(shù)據(jù)庫(kù)的隔離級(jí)別相關(guān)的知識(shí),數(shù)據(jù)庫(kù)操作的隔離級(jí)別,有需要的朋友可以參考下2014-05-05Oracle導(dǎo)dmp出現(xiàn)文件ORA-12154: TNS: 無(wú)法解析指定的連接標(biāo)識(shí)符問(wèn)題的解決方案
這篇文章主要介紹了Oracle導(dǎo)dmp出現(xiàn)文件ORA-12154: TNS: 無(wú)法解析指定的連接標(biāo)識(shí)符問(wèn)題的解決方案,需要的朋友可以參考下2017-03-03Oracle試用到期如何刪除注冊(cè)表繼續(xù)試用30天
這篇文章主要介紹了Oracle試用到期如何刪除注冊(cè)表繼續(xù)試用30天,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-04-04JDBC Oracle執(zhí)行executeUpdate卡死問(wèn)題的解決方案
今天小編就為大家分享一篇關(guān)于JDBC Oracle執(zhí)行executeUpdate卡死問(wèn)題的解決方案,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-12-12oracle實(shí)現(xiàn)一對(duì)多數(shù)據(jù)分頁(yè)查詢篩選示例代碼
這篇文章主要給大家介紹了關(guān)于oracle實(shí)現(xiàn)一對(duì)多數(shù)據(jù)分頁(yè)查詢篩選的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11