2014년 10월 28일 화요일

SGA란?[ORACLE/SQL/HINT/오라클/교육/강의/강좌/SQL교육/오라클 PLSQL/강의/강좌/오라클교육/ORACLE초보교육/오라클실무강좌]

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 
                    단위로 나타낸 것 


 기업100%환급/오라클/자바/스프링/안드로이드/닷넷C#/웹퍼블리싱… 오라클자바…12-272293
 [채용예정교육]오라클자바개발잘하는신입뽑기2개월과정,교육전취…오라클자바…12-111647
53 [평일주간100%환급]Spring,JAVA,JSP,안드로이드,C#닷넷,SQL,튜닝… 오라클자바…03-151456
52 [주말]C#,ASP.NET마스터 오라클자바…01-311567
51 [기업100%환급,평일주간]SQL기초에서스키마오브젝트,PLSQL,힌트… 오라클자바…01-311903
50 [기업100%환급]개발자를위한스프링,마이바티스,하이버네이트(스… 오라클자바…01-311242
49 [평일주간,평일야간,주말]Spring,MyBatis,Hibernate개발자과정 오라클자바…01-191545
48 [평일주간,평일야간,주말]안드로이드개발자과정 오라클자바…01-111369
47 [평일야간,주말주간,주말야간]JAVA,Network&JSP&Spring,MyBatis,… 오라클자바…01-031907
46 기업100%환급/오라클/자바/스프링/안드로이드/닷넷C#/웹퍼블리싱… 오라클자바…12-272293
45 [기업100%환급]자바웹개발기초과정(JAVA,JDBC,JSP,Servlet,Aajx,… 오라클자바…12-191645
44 [평일주간야간, 주말]웹퍼블리싱 마스터(HTML5,CSS3,jQUERY,AJAX… 오라클자바…12-141612
43 [채용예정교육]오라클자바개발잘하는신입뽑기2개월과정,교육전취… 오라클자바…12-111647
42 [주말주간]자바&웹,jQUERY,스프링프레임워크 오라클자바…12-091315
41 [평일야간]닷넷(C#,Network,ADO.NET,ASP.NET)마스터 오라클자바…12-011543
40 [기업100%환급]자바기초&안드로이드개발자과정(Android전액환급… 오라클자바…12-011725
39 [평일야간,주말]SQL기초에서실무까지(SQL기초,PLSQL,힌트,튜닝) 오라클자바…12-011186

댓글 없음:

댓글 쓰기