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
단위로 나타낸 것
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-27 | 2293 | ||
[채용예정교육]오라클자바개발잘하는신입뽑기2개월과정,교육전취… | 12-11 | 1647 | ||
53 | [평일주간100%환급]Spring,JAVA,JSP,안드로이드,C#닷넷,SQL,튜닝… | 03-15 | 1456 | |
52 | [주말]C#,ASP.NET마스터 | 01-31 | 1567 | |
51 | [기업100%환급,평일주간]SQL기초에서스키마오브젝트,PLSQL,힌트… | 01-31 | 1903 | |
50 | [기업100%환급]개발자를위한스프링,마이바티스,하이버네이트(스… | 01-31 | 1242 | |
49 | [평일주간,평일야간,주말]Spring,MyBatis,Hibernate개발자과정 | 01-19 | 1545 | |
48 | [평일주간,평일야간,주말]안드로이드개발자과정 | 01-11 | 1369 | |
47 | [평일야간,주말주간,주말야간]JAVA,Network&JSP&Spring,MyBatis,… | 01-03 | 1907 | |
46 | 기업100%환급/오라클/자바/스프링/안드로이드/닷넷C#/웹퍼블리싱… | 12-27 | 2293 | |
45 | [기업100%환급]자바웹개발기초과정(JAVA,JDBC,JSP,Servlet,Aajx,… | 12-19 | 1645 | |
44 | [평일주간야간, 주말]웹퍼블리싱 마스터(HTML5,CSS3,jQUERY,AJAX… | 12-14 | 1612 | |
43 | [채용예정교육]오라클자바개발잘하는신입뽑기2개월과정,교육전취… | 12-11 | 1647 | |
42 | [주말주간]자바&웹,jQUERY,스프링프레임워크 | 12-09 | 1315 | |
41 | [평일야간]닷넷(C#,Network,ADO.NET,ASP.NET)마스터 | 12-01 | 1543 | |
40 | [기업100%환급]자바기초&안드로이드개발자과정(Android전액환급… | 12-01 | 1725 | |
39 | [평일야간,주말]SQL기초에서실무까지(SQL기초,PLSQL,힌트,튜닝) | 12-01 | 1186 |
댓글 없음:
댓글 쓰기