成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle SGA多個部分的組成

數據庫 Oracle
如果你是Oracle SGA方面的新手,對Oracle SGA的相關實際應用不是很了解的話,以下的文章會給你提供更全面的知識。

如果你想了解Oracle SGA中用到的基本語法的話,你就可以點擊以下的文章對其在實際相關操作中的正確用法,有一個更加完善的認識,以下就是正文的詳細內容的介紹。希望你再瀏覽玩之后會有所收獲。

在《Oracle內存結構研究-PGA篇》一文中提到,PGA是一個服務器進程的專用的私有內存區,而SGA則是共享內存區。

SGA由多個部分組成:

1, 固定SGA(Fixed SGA)

 

2, 塊緩沖區(Db cache)

 

3, 重做日志緩沖區(Redo log buffer)

 

4, Java池(Java pool)

 

5, 大池(Large pool)

 

6, 共享池(Shared pool)

 

7, 流池(Stream pool)

 

有如下參數控制共享池相關組件大?。?/p>

1, JAVA_POOL_SIZE:控制Java池大小。

 

2, SHARED_POOL_SIZE:9i中控制共享池中占用***的部分,10g以上控制共享池大小。

 

3, LARGE_POOL_SIZE:控制大池大小。

 

4, DB_*K_CACHE_SIZE:控制不同塊大小的緩沖區大小。

 

5, LOG_BUFFER:控制重做日志緩沖區大小。

 

6, SGA_TARGET:10g以上控制自動SGA內存管理的總內存大小。

 

7, SGA_MAX_SIZE:控制SGA可以達到的***大小,改變需重啟數據庫。

 

下面將詳細介紹各個部分的作用和推薦設置。

SGA各組件作用

1, 固定SGA:

 

顧名思義,是一段不變的內存區,指向SGA中其他部分,Oracle SGA通過它找到SGA中的其他區,可以簡單理解為用于管理的一段內存區。

 

2, 塊緩沖區:

查詢時,Oracle會先把從磁盤讀取的數據放入內存,以后再查詢相關數據時不用再次讀取磁盤。插入和更新時,Oracle SGA會現在該區中緩存數據,之后批量寫到硬盤中。通過塊緩沖區,Oracle可以通過內存緩存提高磁盤的I/O性能。

 

塊緩沖區中有三個區域:

 

默認池(Default pool):所有數據默認都在這里緩存。

 

保持池(Keep pool):用來緩存需要多次重用的數據。

 

回收池(Recycle pool):用來緩存很少重用的數據。

 

原來只有一個默認池,所有數據都在這里緩存。這樣會產生一個問題:大量很少重用的數據會把需重用的數據“擠出”緩沖區,造成磁盤I/O增加,運行速度下降。后來分出了保持池和回收池根據是否經常重用來分別緩存數據。

 

這三部分內存區需要手動確定大小,并且之間沒有共享。例如:保持池中已經滿了,而回收池中還有大量空閑內存,這時回收池的內存不會分配給保持池。

 

9i開始,還可以設置db_nk_cache。9i之前數據庫只能使用相同的塊大小。9i開始同一個數據庫可以使用多種塊大?。?KB,4KB,8KB,16KB,32KB),這些塊需要在各自的db_nk_cache中緩存。如果為不同的表空間指定了不同的塊大小,需要為其設置各自的緩沖區。

 

3, 重做日志緩沖區(Redo log buffer):

數據寫到重做日志文件之前在這里緩存,在以下情況中觸發:

 

每隔3秒

 

緩存達到1MB或1/3滿時

 

用戶提交時

 

緩沖區的數據寫入磁盤前

 

4, Java池(Java pool):

在數據庫中運行Java代碼時用到這部分內存。例如:編寫Java存儲過程在服務器內運行。需要注意的是,該內存與常見的Java編寫的B/S系統并沒關系。用JAVA語言代替PL/SQL語言在數據庫中寫存儲過程才會用到這部分內存。

 

5, 大池(Large pool):

下面三種情況使用到大池:

 

并行執行:存放進程間的消息緩沖區

 

RMAN:某些情況下用于磁盤I/O緩沖區

 

共享服務器模式:共享服務器模式下UGA在大池中分配(如果設置了大池)

 

6, 共享池(Shared pool)

共享池是SGA中最重要的內存段之一。共享池太大和太小都會嚴重影響服務器性能。

 

SQL和PL/SQL的解釋計劃、代碼,數據字典數據等等都在這里緩存。

 

SQL和PL/SQL代碼在執行前會進行“硬解析”來獲得執行計劃及權限驗證等相關輔助操作。“硬解析”很費時間。對于響應時間很短的查詢,“硬解析”可以占到全部時間的2/3。對于響應時間較長的統計等操作,“硬解析”所占用的時間比例會下降很多。執行計劃及所需的數據字典數據都緩存在共享池中,讓后續相同的查詢可以減少很多時間。

 

不使用“綁定變量”導致:

 

系統需要花費大量的資源去解析查詢。

 

共享池中的代碼從不重用,系統花費很大代價管理這部分內存。

 

關于共享變量的優缺點討論已經超過了這篇文章的范疇,簡單來講,響應時間短的查詢要使用共享變量,響應時間長的統計不使用共享變量。

 

需要注意的是,SHARED_POOL_SIZE參數在9i中控制共享池中占用***的部分,10g以上控制共享池總大小。

 

7, 流池(Stream pool)

9iR2以上增加了“流”技術,10g以上在SGA中增加了流池。流是用來共享和復制數據的工具。

 

上述的相關內容就是對Oracle SGA的描述,希望會給你帶來一些幫助在此方面。 

【編輯推薦】

  1. Oracle to_char的用法描述
  2. Oracle 多表關聯如何更新多個字段
  3. Oracle存儲過程的開發的介紹
  4. Oracle數據庫中表的不同的連接方式描述
  5. 配置Oracle RAC中應注意的問題有哪些
責任編輯:佚名 來源: 博客園
相關推薦

2010-10-28 14:29:39

Oracle內存結構

2010-04-12 16:03:12

Oracle SGA設

2010-04-08 09:00:29

Oracle內存結構

2009-02-01 10:45:18

Oracle數據庫性能調整

2010-04-13 11:35:26

Oracle字符集

2010-04-09 15:15:01

Oracle SGA

2011-07-29 15:58:53

SGAOracle

2010-04-13 15:49:02

Oracle SGA

2010-03-31 10:40:11

Oracle事例

2010-03-31 10:30:03

Oracle 10g

2010-04-01 17:14:04

Oracle索引

2009-09-08 09:37:03

LINQ重要組成部分

2010-06-30 10:02:05

UML建模技術

2009-07-28 15:28:35

ASP.NET AJA

2009-07-07 17:39:26

JSP系統

2010-06-29 19:31:48

UML建模技術

2010-01-22 18:41:32

Visual C++

2009-06-04 07:55:08

Struts框架簡介Struts

2010-05-25 16:56:05

voip系統組成

2010-03-02 13:23:11

Android手機程序
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一区二区三区四区在线视频 | 日日干日日色 | 日韩精品一区二区三区在线播放 | 久久久久国产一区二区三区 | 欧美日韩视频在线播放 | 国内精品视频在线观看 | 精品视频一区二区三区在线观看 | 91视频在线看| 日本aa毛片a级毛片免费观看 | 久久网站免费视频 | 亚洲欧美综合精品久久成人 | 激情福利视频 | 久久伊人操 | 久草热播 | 国产精品欧美一区二区三区不卡 | 欧美极品在线观看 | 黄色大片在线免费观看 | 久久国产精品久久久久久久久久 | 免费av手机在线观看 | 日日干夜夜操 | 免费在线一区二区 | 日本三级播放 | 国产精品成人一区二区 | 亚洲精品欧美一区二区三区 | 91精品国产综合久久婷婷香蕉 | 久久久久久亚洲精品不卡 | 午夜精品一区二区三区在线 | 中国美女撒尿txxxxx视频 | 国产成人福利在线观看 | 国产在线一区二区 | 一级在线视频 | 国产激情第一页 | 欧洲精品码一区二区三区免费看 | 精品欧美黑人一区二区三区 | 亚洲一一在线 | 99pao成人国产永久免费视频 | 逼逼网| 成人免费观看网站 | 国产在线一区二区 | 天天爱爱网 | 国产精品国产三级国产aⅴ浪潮 |