################################################################
1. Backup 하기
################################################################
1. 백업 가능대상
- database (all datafile 과 현재 control file)
- tablespace
- datafile (current 또는 image copy)
- archived redo log
- control file (current 또는 image copy)
* 백업이 되는 않는 대상( init.ora, password file. listener.ora, tnsnames.ora, BFILES등) |
2. 백업 분류
- consistent vs Inconsistent 백업
RMAN을 통한 백업은 대상 DB가 open 혹은 close된 시점에서 백업이 가능하며, open된 상태에서의 백업은 항상 Inconsistent 이며, consistent 백업은 항상 mount상태에서 백업을 받은 것을 말하며 이전에 DB가 crash되거나 비 정상 종료가 되지 않아야 한다.
( NOARCHIVE MODE에서는 INCONSISTENT 백업을 허용하지 않는다) |
3. 백업 방법
3.1 전체 database 백업
run {
allocate channel c1 device type disk;
backup database
format ‘/data/backup/rman/%d_%p_%t’;
} |
3.2 tablespace 백업
run {
allocate channel c1 device type disk;
allocate channel c2 device type disk;
allocate channel c3 device type disk;
backup filesperset=3 ## 한 백업set에 datafile 3개를 넘어서 백업받지 않는 조건
tablespace example , users,system
include current controlfile; ## 현재 control file도 같이 백업
} |
3.3 datafile 백업
run {
allocate channel c1 device type disk;
backup datafile 1, 2, 3, 4, 5, 6 ;
} |
3.4 datafile copy
run {
allocate channel c1 device type disk;
backup datafilecopy ‘/home/oracle/oradata/testdb/users01.dbf’
format ‘/data/backup/rman/users01.bak’;
} |
3.5 current control file 백업
run {
allocate channel ch1 type disk;
backup current controlfile
tag = mondayPMbackup;
} |
3.6 다른 object 백업시 control file 백업 추가 방법
run {
allocate channel ch1 type disk;
backup tablespace users
include current controlfile; ## users 라는 tablespace 백업시 currnet control file 포함
} |
3.7 Archive된 redo log 백업
run {
allocate channel ch1 type disk;
backup archivelog all ## archive된 모든 redo log 백업
delete input; ## 백업받은 archive log 삭제
}
* archived redo log 백업시 time, SCN, log sequence number 조건을 사용해서 백업 받을수 있다.
예) time 조건
run {
allocate channel ch1 type disk;
backup archivelog
from time ‘SYSDATE-2’ until time ‘SYSDATE-1’; ## 2일전부터 1일전까지 발생한 archived redolog
} |
4. incremental 백업
run {
allocate channel ch1 type disk;
backup incremental level=0 ## level 0 으로 database incremental backup
database;
}
run {
allocate channel ch1 type disk;
backup incremental level=1 ## level 1로 system tablespace와 sale.f datafile 을 백업
tablespace system ## 하는데 level 0 또는 1이후로 변경된 사항만
datafile ‘/home/oracle/oradata/testdb/example01.dbf’; ## 백업받는다.
}
run {
allocate channel ch1 type disk;
backup incremental level=2 cumulative ## level 2로 tbs_1 tablespace 백업하는데 level 0 또는 1
tablespace example; ## 이후로 변경된 사항만 백업(cumulative 옵션사용)
}
|
5. image copies
1. datafile
2. archived redo log
3. control file |
5.1 datafile과 controlfile image copy 예
예1)
run {
allocate channel ch1 type disk;
copy
datafile 1 to ‘/data/backup/rman/df_1.bak,
datafile 2 to ‘/data/backup/rman/df_2.bak’,
datafile 3 to ‘/data/backup/rman/df_3.bak’,
datafile 4 to ‘/data/backup/rman/df_4.bak’,
current controlfile to ‘/data/backup/rman/control.bak;
} |
################################################################
Restore
################################################################
1. Restore Datafile, Controlfile, Archived redo log file
- restore 명령으로 백업set이나 image copy본에서 restore가능하다.
(image copy본은 disk에서만 가능) |
2. restore database
- database restore시에는 db는 항상 close상태이어야 한다. (db가 open된 상태라면 아래와 같이 shutdown 후, startup mount 상태로 한다.)
shutdown immediate
startup mount
ex) 기존의 datafile 위치에 database를 restore 하는경우
run {
allocate channel ch1 type disk;
allocate channel ch2 type disk;
allocate channel ch2 type disk;
restore database;
} |
3. tablespace 와 datafile restore
3.1 기존위치에 tablespace restore
run {
sql ‘alter tablespace example offline ’;
allocate channel ch1 type disk;
restore tablespace example;
} |
3.2 새로운 위치에 tablespace restore
run {
allocate channel ch1 type disk;
sql ‘alter tablespace example offline’ ;
## 새로운 위치에 datafile restore
set newname for datafile ‘/home/oracle/oradata/testdb/example01.dbf’
to ‘/home/oracle/temp/example01.dbf’;
restore tablespace example;
## 변경된 위치로 control file이 인식할 수 있게 함
switch datafile all;
} |
4. control file restore
- nomount 단계에서 restore 해야함
run {
allocate channel ch1 type disk;
restore controlfile;
alter database mount;
} |
5. Archived redo log restore
- mount 단계에서 restore
run {
## init.ora 에 명시되어있는 log_archive_dest 위치가 아니 다른 위치에 restore하고자 할때
set archivelog destination to ‘/oracle/temp_restore’;
allocate channel ch1 type disk;
restore archivelog all;
} |
################################################################
Recovery
################################################################
1. Complete Recovery
1.1 recover database
shutdown immediate;
startup mount;
run {
allocate channel ch1 type disk;
restore database;
recover database;
} |
1.2 recover database (control file 백업본을 restore하고 복구하는 경우)
startup nomount;
run {
allocate channel ch1 type ‘sbt_tape’;
restore controlfile;
alter database mount;
restore database;
recover database;
alter database open resetlogs;
}
* resetlogs로 database를 open한 경우 reset database명령수행이 필요하며, 다시 database를 백업받는다. |
1.3. recover tablespace
1.3.1 database가 close상태이고 tablespace위치에 접근가능할 때
run {
allocate channel ch1 type disk;
restore tablespace tbs_3;
recover tablespace tbs_3;
} |
1.3.2 database가 close상태이고 tablespace위치에 접근가능하지 못할 때
(datafile 위치를 바꿀 필요가 있을때)
run {
allocate channel ch1 type disk;
set newname for datafile ‘/disk1/oracle/tbs_1.f’ to ‘/disk2/oracle/tbs_1.f’;
restore tablespace tbs_1;
switch datafile all;
recover tablespace tbs_1;
} |
1.3.3 database가 open된 상태이고 tablespace위치에 접근가능할 때
run {
sql ‘alter tablespace user_data offline temporary’;
allocate channel ch1 type disk;
set archivelog destination to ‘/oracle/temp/arc1_restore’;
restore tablespace user_data;
recover tablespace user_data;
sql ‘alter tablespace user_data online’;
} |
1.3.4 database가 open된 상태이고 tablespace위치에 접근불가능할 때
run {
sql ‘alter tablespace tbs_1 offline temporary’;
allocate channel ch1 type disk;
set newname for datafile ‘/disk1/oracle/tbs_1.f’ to ‘/disk2/oracle/tbs_2.f’;
restore tablespace tbs_1;
switch datafile all;
recover tablespace tbs_1;
sql ‘alter tablespace tbs_1 online’;
} |
2. Incomplete Recovery
2.1 time base Incomplete Recovery
time base로 Incomplete Recovery를 하고자 할 때는 time format을 확인한 후 작업해야 한다.
(필요시 time format설정 변경)
예) NLS_LANG=american
NLS_DATE_FORMAT=’Mon DD YYYY HH24:MI:SS’
database open시는 반드시 shutdown후 작업
shutdown immediate;
startup mount;
run {
set until time ‘Nov 15 1998 09:00:00’;
allocate channel ch1 type ‘sbt_tape’;
restore database;
recover databse;
alter database open resetlogs;
}
resetlogs로 database open후 반드시 recovery catalog database에 reset database 명령으로 초기화 후 target database를 백업 받도록 한다.
|
2.2 특정 SCN까지 recovery
database open시는 반드시 shutdown후 작업
shutdown immediate;
startup mount;
run {
set until scn 1000;
allocate channel ch1 type ‘sbt_tape’;
restore database;
recover database;
alter database open resetlogs;
}
resetlogs로 database open후 반드시 recovery catalog database에 reset database 명령으로 초기화 후 target database를 백업 받도록 한다.
|
2.3 특정 log sequence까지 recovery
어느시점까지 recovery할것인지는 v$log_history view 조회를 통해서 결정
database open시는 반드시 shutdown후 작업
shutdown immediate;
startup mount;
## thread 1에 대해 log sequence 6 까지 recovery하는 예
run {
set until logseq 6 on thread 1;
allocate channel ch1 type ‘sbt_tape’;
restore database;
recover database;
alter database open resetlogs;
}
resetlogs로 database open후 반드시 recovery catalog database에 reset database 명령으로 초기화 후 target database를 백업 받도록 한다. |
3. recovery catalog 없이 DBPITR(DataBase Point In Time Recovery)할때
- recovery catalog 없이 DBPITR 수행을 하고자 할때는 아래와 같은 몇가지 필요한 사항들이 있다
- control file은 별도로 백업을 받아 두도록 한다.
database 백업시 control file도 자동으로 백업을 받아지기는 하지만 그때 발생한 database 백업에 대한 정보를 가지고 있지 못하기 때문에 별도로 아래와 같이 백업을 받도록 한다.
backup database;
backup current controlfile tag = ‘database backup’;
controlfile 백업시 tag 옵션을 사용하여 향후에 특정시점에 백업받은 controlfile을 사용할 수 있도록 한다.
- tablespace 변경 시나 datafile 추가시 백업을 수행하도록 한다.(control file도 포함)
예)
catalog없이 rman 시작
rman target / nocatalog
만일 database가 open된 상태라면 shutdown후 mount시킨다.
startup force mount;
특정 임시위치에 control file restore
run {
set until time ‘Jun 18 1998 16:32:36’;
allocate channel ch1 type disk;
restore controlfile to ‘/tmp/cf.tmp’ from tag = ‘database backup’;
}
백업받은 특정 controlfile을 restore할 수 없을 때는 rman을 통해 restore받은 controlfile을 아래와 같은 sql 명령으로 백업받은 후 init.ora 관련 파라미터를 조정한후 다음단계를 수행하도록 한다.
- sql > alter database backup controlfile to ‘/tmp/original_cf’;
- database shutdown
- init.ora 에 명시된 CONTROL_FILES 파라미터를 적절히 조정
- 백업받은 controlfile을 적당한 위치에 copy
- startup mount
run {
set until time ‘Jun 18 1998 16:32:36’;
allocate channel ch1 type disk;
restore database;
recover database noredo; ## database가 Noarchive Mode일때 noredo 옵션사용
alter database open resetlogs; ## Archive Mode일때는 noredo 옵션없이 recover한다.
} |
출처 : cafe.naver.com/prodba