2013년 8월 4일 일요일

Oracle SGA(Oracle System Global Area)

SGA는 DataBase Buffer Cache,Redo Log Buffer, Shared Pool등으로 구성된다. 
1.DataBase Buffer Cache 
- DataFile로 부터 읽어들인 Data Block의 복사본을 가지고 있습니다. 
- Cache내의 Buffer에는 수정되었지만 디스크에 기록되지 않은 Dirty Buffer와 
빈버퍼,고정된버퍼,아직 더티목록으로 이동되지 않은 더티목록등으로 구성되는 
LRU목록등이 있다. 
- Oracle은 사용자 프로세스가 빈버퍼를 찾지 못하고 버퍼의 임계점에 도달하면 
프로세스는 LRU목록 검색을 중지하고 Dirty Buffer를 Disk에 기록하도록 DBWR에 
신호를 보낸다. 
- 초기 Parameter DB_BLOCK_BUFFERS는 DB의 DataBase Buffer Cache의 Buffer수를 지 
정합니다. Cache의 Buffer는 하나의 Oracle Data Block과 동일하며,Cache는 제한된 
크기이므로 Cache가 가득찬후 Cache실패가 발생하면 Oracle은 Cache에 있는 Data를 
디스크에 기록한다. 
- size가 작으므로 발생 할 수 있는 현상은 빈번한 디스크 I/O이다. 크기는 db_block_buffers로 
지정하며 buffer의 갯수를 지정한다. 
  byte 산정은 db_block_buffers * db_block_size로 산출된다.        

2.Redo Log Buffer 
- DataBase의 변경사항 정보를 유지하는 SGA에 있는 원형 Buffer 
- BackGround 프로세스인 LGWR는 Redo Log Buffer를 디스크상에서 사용중인 Online 
Redo Log File Group에 기록한다. 
- Redo Log Buffer의 크기는 Parameter LOG_BUFFER로 결정한다 
큰 값을 가질경우 Log File의 I/O가 감소하며,트랜잭션이 길고 수가 많은 경우에 특히 더감소한다. 
기본크기는 OS DataBlock의 4배임. 

3.공유풀(Shared Pool) 
A. Library Cache 
- 공유 SQL영역, 전용SQL영역,PL/SQL Procedure와  Package, 잠금장치나 Library 
    Cache Handle과 같은 제어구조를 포함한다. 
  - 공유 SQL영역은 단일 SQL명령문에 대한 구문분석 트리와 실행계획을 가지는 영 
    역이며, 전용SQL영역은 바인드정보나 실행 시간 버퍼(SQL이 실행되는 동안 사용 
    되는 정보, Insert/Update/Delete보다 Select가 많음) 같은 데이터를 가지는 영역 
  - 전용SQL여역을 관리하는 것은 사용자 프로세스이고,사용자 프로세스가 할당할수 
    있는 전용SQL영역의 수는 OPEN_CURSORS(Default 50)로 제한 되지만 전용SQL 
    영역할당 또는 해제는 사용자가 사용하는 응용프로그램 도구에 의해 좌우됨 
B. Dictionary Cache 
- Data Dictionary(Table/View의 이름,Column이름과유현,Oracle사용자 권한)는 자주 
    Access되므로 메모리에 두개의 특별한 위치를 지정하여 Dicitonary  Data를 저장 

 - 공유풀에서 메모리 할당 및 재사용 
공유풀에 있는 항목은 수정된 LRU 알고리즘에 의해 지워질 때 까지 남아있다. 
Oracle은 공유풀을 확인하여 동일한 명령문이 공유풀에 있는지 확인한다. 
이때 같은 Query라도 대순자를 틀리게하여 Query하는 경우에는 틀린것으로 인식하여 
또다른 공유풀의 영역을 할당한다.(즉 SELECT * FROM EMP와 select * from emp는 다르게 인식) 
이렇게 함으로서 메모리를 절약하며,수행능력이 향상된다. 
- ANALYZE명령어를 사용하여 Table/Cluster/Index의 통계를 할경우 분석된 개체를 참조하는 
명령문을 포함하는 모든 공유 SQL영역이 공유풀에서 지워진다. 
- SGA의 크기는 Instance 시작시에 결정되며 대부분의 시스템에서 성능을 최적화 하려면 전체 
SGA의 크기가 실제 Memory 크기에 맞아야 한다.가상메모리를 사용하면 OS가 SGA의 일부를 
Page 하므로 시스템 성능이 급격히 떨어진다. 

- SGA의 크기에 영향을 주는 Parameter 
DB_BLOCK_SIZE : 하나의 Data Block과 DataBase Buffer크기를 Byte 단위로 나타낸 것 
DB_BLOCK_BUFFERS : DB_BLOCK_SIZE인 데이터베이스 Buffer수를 나타냄 
LOG_BUFFER : 리두로그 버퍼에 대한 할당된 바이트수 
SHARED_POOL_SIZE : 공유SQL영역과 PL/SQL명령문에 할당된 영역의 크기를 Byte 
                    단위로 나타낸 것 


[출처]오라클자바커뮤니티, 오엔제이프로그래밍
www.onjprogramming.co.kr

댓글 없음:

댓글 쓰기