Clone DB && DB Link (drop table 복구)
- drop table 된 Data 를 clone DB 와 DB Link 를 이용하여 복구해 보겠습니다.
- 우선 archive mode 를 확인 합니다.
- 오픈 백업을 수행 합니다.
- 실습을 위해 다음과 같이 Table 을 생성하고 Data를 삽입 합니다.
SQL> create table scott.ctest01
2 (no number,
3 name varchar2(10),
4 address varchar2(20)) tablespace clone_test;
SQL> begin
2 for i in 1..100000 loop
3 insert into scott.ctest01 values(i,dbms_random.string('A;,10),dbms_random.string('A',20));
4 end loop;
5 commit;
6 end;
7 /
- 로그 마이어로 확인 하거나 다음과 같이 시간을 기록해 둡니다.
- 운영 DB 에서 PFile을 복사하여 CloneDB용 Pfile 을 생성합니다.
- 컨트롤 파일의 경로와 디비 명을 바꿔 주셔야 합니다.
$cp inittestdb.ora initclone1.ora
- 그리고 원본 testdb 즉 운영 DB 에서 컨트롤 파일 생성 스크립트를 만듭니다.
- Redo log file 을 이용하여 복구를 할 수 없고 Archive log 를 이요하여야 하기 때문에 Resetlogs 용으로 스크립트를 수정합니다.
$export ORACLE_SID=clone1
- 그리곤 생성한 스크립트를 이용하여 DB 를 Mount 단계까지 올려 줍니다.
- recover database 쿼리를 이용하여 아까 기록한 시간대로 복구를 해주어야 합니다. 물론 controlfile 의 SCN 이 다르기 때문에 using backup controlfile 구문도 추가해 주어야 합니다.
SQL>alter database open resetlogs;
- resetlogs 옵션으로 DB 를 Open 시킵니다.
- 그리고 Data 가 복구 되었는지 확인 합니다.
- 복구가 된 것을 확인 할 수 있습니다.
- 운영서버(testdb)에서 clone DB로 DB Link 생성하기
- 운영서버의 ORACLE_HOME/network/admin/tnsnames.ora 수정
- 만약 tnsnames.ora 파일이 존재하지 않는다면 netca 를 실행하여 리스너 구성을 해주시기 바랍니다.
- ORACLE_HOME/network/admin/listener.ora
- 운영DB 의 listener.ora 파일에서 Clone DB 의 리스너 정보를 등록 시켜줘야 합니다.
- 이제 운영서버에서 Clone DB 로 연결하는 DB Link 를 생성합니다.
SQL> create database link clink ß DB Link 명(임의로 지정)
2 connect to scott identified by tiger ß clone DB에 연결할 계정
3 using 'clonedb'; ß 이 이름은 tnsnames.ora 파일에 있는 이름을 사용하여야 합니다.
-리스너를 중지 시키고 다시 실행 시키면서 리스너를 테스트 해 봅시다.
- 다음은 리스너를 중지 시키고 연결 되는지 확인해 봅니다.
-다시 리스너를 실행 시킵니다. (listener2)
- listener2 의 상태를 확인 합니다.
- tnsping clonedb 명령어를 통해 리스너가 제대로 동작하고 통신이 되는지 확인 합니다.
- 운영 DB 에서 Clone DB 로 접속할 수 있는지 확인 합니다.
SQL> select count(*) from scott.ctest01@<DBLink명>
- 다음과 같은 방법으로 Clone DB 에서 복구한 Data 를 가져 옵니다.