DB ORACLE 공부 기록
Redo log 이중화 및 STATUS
레연
2022. 12. 21. 10:27
Redo log
- DB에서 발생하는 모든 변경사항 기록하는 파일
- 장애시 복구를 위한 DML 문장 저장 (데이터 파일에 쓰여지지 않은 커밋된 데이터를 복구하기 위해서 사용)
- LGWR은 그룹 내의 모든 리두 로그 파일에 동시에 동일한 정보를 기록
- 최소 2개 이상의 리두 로그 그룹이 필요
- 리두로그 그룹내 멤버는 서로 다른 디스크에 저장 권고
- 각 그룹내 리두로그 멤버는 이중화 권고
*리두로그 파일 그룹 크기를 증가시키거나 감소시키려면 새로운 리두로그 파일 그룹을 추가 후 이전 리두로그 파일 그룹을 삭제
STATUS : 로그 상태
V$LOG 에서 확인 가능
Status | 설명 |
UNUSED | 온라인 리두 로그가 기록된 적이 없음 새로 추가된 Redo log일 경우 |
CURRENT | 현재 리두 로그 리두 로그가 활성화된 상태 |
ACTIVE | 로그가 Active 상태지만 현재 리두로그는 아닌 상태 Check Point 이전 상태 crash recovery에 필요 블록복구에 사용 중일 수 있음 보관할 수도 있고 안할 수도 있음 |
CLEARING | ALTER DATABASE CLEAR LOGFILE 명령문 이후에 빈 로그로 다시 생성됨 로그가 지워지면 UNUSED 상태로 변경됨 |
CLEARING_CURRENT | 닫힌 스레드에서 현재 로그를 지우는 중인 상태 |
INACTIVE | 인스턴스 복구에 더이상 필요 없는 상태 Check Point 완료 이후의 상태 media reovery에 사용 중일 수 있음 보관할 수도 있고 안할 수도 있음 |
Redo log 그룹 내 멤버 이중화
Redo log File 정보
리두로그 그룹 3개, 리두로그 파일이 그룹 내 단일 구성으로 되어있는 것을 확인
SELECT a.thread# "Thread#"
, a.group# "Group#"
, b.member "Logfile"
, a.bytes/1024/1024 "Size (MB)"
, a.status
, a.sequence#
FROM v$log a
, v$logfile b
WHERE a.group#=b.group#
ORDER BY 1, 2, 3
리두로그 멤버 추가
SQL> alter database add logfile member '/u01/app/oracle/oradata/ORCL/redo01_2.log' to group 1;
Database altered.
SQL> alter database add logfile member '/u01/app/oracle/oradata/ORCL/redo02_2.log' to group 2;
Database altered.
SQL> alter database add logfile member '/u01/app/oracle/oradata/ORCL/redo03_2.log' to group 3;
Database altered.
Redo log File 정보 재확인
SELECT a.thread# "Thread#"
, a.group# "Group#"
, b.member "Logfile"
, a.bytes/1024/1024 "Size (MB)"
, a.status
, a.sequence#
FROM v$log a
, v$logfile b
WHERE a.group#=b.group#
ORDER BY 1, 2, 3
Log switch 발생
SQL> ALTER SYSTEM SWITCH LOGFILE;
System altered.
Redo log File 정보 재확인
SELECT a.thread# "Thread#"
, a.group# "Group#"
, b.member "Logfile"
, a.bytes/1024/1024 "Size (MB)"
, a.status
, a.sequence#
FROM v$log a
, v$logfile b
WHERE a.group#=b.group#
ORDER BY 1, 2, 3
리두로그 그룹 2를 사용하고 있었는데 로그스위치로 인하여 그룹2의 상태는 ACTIVE 상태가 된다.
Log switch 두번 더 발생
다시 그룹2가 CURRENT 상태가 되고 나머지 그룹1, 3은 ACTIVE 상태가 된다.
Check point 발생
SQL> ALTER SYSTEM CHECKPOINT;
System altered.
Redo log File 정보 재확인
SELECT a.thread# "Thread#"
, a.group# "Group#"
, b.member "Logfile"
, a.bytes/1024/1024 "Size (MB)"
, a.status
, a.sequence#
FROM v$log a
, v$logfile b
WHERE a.group#=b.group#
ORDER BY 1, 2, 3
체크포인트 발생으로 그룹1, 3의 상태는 INACTIVE 상태가 된다.