imp 시의 속도향상을 위한 팁

2010.10.13 15:15

조인상 조회 수:14038

원문 : http://www.ischo.net -- 조인상 // 시스템 엔지니어

Writer : http://www.ischo.net -- ischo // System Engineer in Replubic Of Korea

+++++++++++++++++++++++++++++++++++++++++++++++++++++++

 

원문 : http://www.ischo.net -- 조인상 //시스템 엔지니어

출처 : OTN
+++++++++++++++++++++++++++++++++++++++++++++++++++++++

No. 11193

TIPS(49) : IMPORT PERFORMANCE TIPS
==================================

PURPOSE


[Import 의 Performance]
Oracle import를 실행 시 많이 걸리는 시간을 줄이기 위해 다음의 현상을
적용해 보자.

Explanation


1) System 적 변경

- DB 를 다시 create 할 경우 DB_BLOCK_SIZE를 증가시킨다.
이 block size 가 큰 경우, 더 작은 I/O cycle 이 발생한다.
이 변경값이 permanent한 경우는 변경 전과 비교한 모든 효과를 고려한다.

- 1개의 커다란 rollback segment 를 생성하고, 이외의 rollback segment는
모두 offline 한다.

- 1개의 rollback segment는 import 되어질 table 중 가장 큰 것의 50%
정도로 잡는다. import 는 기본적으로 insert into table_name values
(,,,,,) 이고 이 경우 rollback segment 에는 rowid 만 들어가게 되므로
2개의 같은 size 인 extent를 갖는 rollback 을 생성하면 된다.

- import 가 끝날 때까지 database 를 NOARCHIVELOG mode로 유지한다.
이는 archive log 를 생성하는 overhead 를 없앨 수 있다.

- rollback segment와 마찬가지로, 커다란 redo log file을 생성한다.
클수록 log switch 가 발생하지 않으므로 import 시는 좋다.
작은 size 의 redo log 는 offline 하도록 한다. alert.log 에 나타나는
'Thread 1 cannot allocate new log, sequence 17, Checkpoint not
complete'의 메시지는 좀 더 크거나 더 많은 갯수의 redo log file 이
필요함을 나타낸다.

- 가능하다면 table, rollback, redo log file 이 다른 disk에 있도록 한다.
이는 i/o contention을 줄일 수 있다.

2) Init.ora Parameter 변경

- LOG_CHECKPOINT_INTERVAL을 redo log file의 size 보다 크게 준다.
이 숫자는 OS block 을 의미하여 unix 에서는 512 byte 이다.
이를 크게 하면 log swich time을 줄일 수 있다.

- SORT_AREA_SIZE를 증가시킨다.
인덱스를 아직 생성하지 않았다 하더라도, unique, primary key는 있기
때문이다.
이 값의 증가는 같은 machine 안에 별도의 어떤 작업이 있는가,
free memoty 가 얼마 만큼 있느냐에 따라 다르긴 하지만 평상 시의 5-10
배로 한다.
만일 machine이 swapping이나 paging이 발생하면 더욱 크게 해준다.

3) Import Options 변경

- COMMIT=N option을 사용한다.
이를 사용하면 buffer의 data 가 insert되고 commit함이 아니라, 각
object(table) 의 모든 data가 insert 후 commit 된다.
만일 rollback 이 작다면 이 option 을 이용할 수 없다.

- BUFFER 크기를 크게 한다.
이것 역시 시스템의 다른 activity 나, 데이타베이스 크기에 따라 다르다.
이 값이 크면 export file을 access 하는 횟수를 줄일 수 있다.

- import 시 INDEXES=N option을 사용한다.
만일 index를 생성 시는 SORT_AREA_SIZE 는 더욱 커야 한다.


Reference Documents



none

글 수정:
Min Angel (Yeon Hong Min, Korean)

번호 제목 글쓴이 날짜 조회 수
95 오라클 튜닝 - 옵티마이저 조인상 2010.05.12 7332
94 9i 에서의 언두세그먼트 관리 조인상 2010.05.12 7342
93 캐릭터셋 변경방법 조인상 2010.05.12 7356
92 time-based recovery 조인상 2010.08.24 7417
91 오라클 온라인백업스크립트 구성 예 조인상 2010.05.12 7442
90 [oerr] ORA-19206: Invalid value for query or REF CURSOR parameter 조인상 2010.05.12 7479
89 오라클 10g OCP 라이센스 업그레이드 정보 조인상 2010.05.12 7519
88 테이블스페이스 사용현황 확인하는 스크립트 조인상 2010.05.12 7568
87 Redhat Linux 8.0 에 Oracle 9i install 조인상 2010.05.12 7616
86 골든 5.7 버전 데모 file 조인상 2010.05.12 7864
85 테이블의 특정 컬럼에 걸려있는 제약 조건의 확인 조인상 2010.05.12 7978
84 Oracle Flashback 복구 조인상 2010.05.12 7985
83 Red Hat Enterprise Linux AS release 3 (Taroon) 기반에서 오라클 9.2.0 설치하기 조인상 2010.05.12 8084
82 [9i feature] DB_CACHE_ADVICE / V$DB_CACHE_ADVICE 에 대해서 조인상 2010.05.12 8091
81 캐릭터셋 확인하는 쿼리 조인상 2010.05.12 8121
80 처음 오라클 설치시 SGA 영역크기 정하는 규칙 조인상 2010.05.12 8347
79 ORA-01632 조인상 2010.05.13 8437
78 제약조건 이름은 아는데 테이블을 모를경우 찾는 스크립트 조인상 2010.05.12 8448
77 레드햇리눅스9에 오라클9i설치중 hang 조인상 2010.05.12 8788
76 Oracle Library Cache and Dictionary Cache 조인상 2010.05.12 8846
서버에 요청 중입니다. 잠시만 기다려 주십시오...