Database
[DataBase ⑤] DB 장애와 회복 (트랜잭션 / 장애 / 회복)
비전공자 기록광
2021. 10. 7. 11:08
반응형
DB 복습 INDEX
① DB 기본 이론 (DBMS 개념 / 데이터 언어)
② 데이터 모델링 (데이터모델 / 객체 / 속성)
③ 정규화 (이상현상 / 이행적 함수 종속)
④ 관계 데이터연산 (관계 대수 /관계해석 /SQL)
⑤ 트랜잭션 (트랜잭션 / 장애 / 회복)
트랜잭션 Transaction
트랜잭션은 DB 상태를 변화시키기 위해 논리적 기능을 수행하는 하나의 작업 단위을 말한다.
쉽게 말해 한번에 수행되어야할 연산의 집합을 말한다.
트랜잭션은 Commit 혹은 Rollback 작업을 수행한다.
- 커밋 Commit : 트랜잭션 작업의 논리적 단위가 성공적으로 완료되었음을 알리는 연산자
- 롤백 Rollback : 트랜잭션 작업이 실행 실패되었음을 알리고 결과를 원상 복구 시키는 연산자
트랜잭션 특징
- 원자성 : 트랜잭션 연산은 DB에 모두 반영되거나 전혀 반영되지 않아야 한다. (All or Noting)
- 일관성 : 트랜잭션 실행이 성공적으로 완료되면 DB는 일관성 있는 상태가 된다.
- 독립성 : 트랜잭션 실행 중에 있는 연산의 중간 결과에 다른 트랜잭션이 접근할 수 없다.
- 영속성 : 트랜잭션이 일단 실행 완료되면 결과는 영구적이다.
트랜잭션 상태
- Active : 트랜잭션 실행 중
- Failed : 트랜잭션 실행 중 오류 / 중단
- Aborted : 트랜잭션 실행 실패 / 철회 → 롤백
- Partially Commited : 트랜잭션의 마지막 연산까지 실행했지만 Commit 직전의 상태
- Commit : 트랜잭션 실행 완료
장애
장애는 쉽게 말해 DB 실행 오류이다.
장애 발생시 회복 작업의 단위가 바로 트랜잭션이 된다.
장애 종류
- 트랜잭션 장애 : 트랜잭션 수행 오류
- 시스템 장애 : 하드웨어의 결함으로 인한 오류
- 미디어 장애 : 디스크 장치 결함
회복
트랜잭션 수행 중 장애로 인해 손상된 DB를 이전 상태로 복구시키는 작업
회복 연산
- 덤프 Dump : DB 전체를 다른 저장장치에 주기적으로 복사하는 연산
- 로그 Log : DB에서 갱신 연산 실행될때마다 데이터 갱신 이전 값과 이후 값을 별도의 파일에 기록하는 연산
- 재실행 Redo : DB 복사본 가져와 로그 이용해 발생 직전 DB 상태로 복구하는 연산 → 트랜잭션 완료 전 장애 발생한 경우
- 취소 Undo : 로그 이용해 실행된 갱신 연산을 취소해 DB의 원래 상태로 복구하는 연산 → 트랜잭션 완료 후 장애 발생한 경우
회복 기법
- 로그 회복 기법
- 지연 갱신 회복 기법 : 트랜잭션의 데이터 갱신 연산 결과 로그 파일에만 기록, 트랜잭션 부분 완료 후 DB 반영
- 즉시 갱신 회복 기법 : 트랜잭션 수행 중 데이터 갱신 연산 결과 DB와 로그 파일에 즉시 반영, 기록
- 검사시점 회복 기법 : 로그 이용하지만 일정시간 간격으로 검사시점 만들어 두고 장애 발생하면 가장 최근 검사시점 이후 트랜잭션에만 회복작업 수행
- 미디어 회복 기법 : 전체 DB 일정주기마다 안전한 저장장치에 복사하는 기법 (덤프) → 디스크 장애에 대비한 회복 기법
반응형