DBMS-데이터 복구
충돌 복구
DBMS는 매초 수백 개의 트랜잭션이 실행되는 매우 복잡한 시스템입니다. DBMS의 내구성과 견고성은 복잡한 아키텍처와 기본 하드웨어 및 시스템 소프트웨어에 따라 달라집니다. 트랜잭션 중에 실패하거나 충돌하는 경우 시스템은 손실 된 데이터를 복구하기 위해 일종의 알고리즘 또는 기술을 따를 것으로 예상됩니다.
실패 분류
문제가 발생한 위치를 확인하기 위해 다음과 같이 다양한 범주로 실패를 일반화합니다.
거래 실패
트랜잭션은 실행에 실패하거나 더 이상 진행할 수없는 지점에 도달하면 중단해야합니다. 이를 트랜잭션 실패라고하며 소수의 트랜잭션 또는 프로세스 만 손상됩니다.
거래 실패의 원인은 다음과 같습니다.
Logical errors − 일부 코드 오류 또는 내부 오류 조건이있어 트랜잭션을 완료 할 수없는 경우.
System errors− DBMS가 트랜잭션을 실행할 수 없기 때문에 데이터베이스 시스템 자체가 활성 트랜잭션을 종료하거나 시스템 상태에 따라 중지해야하는 경우. 예를 들어 교착 상태 또는 리소스를 사용할 수없는 경우 시스템은 활성 트랜잭션을 중단합니다.
시스템 충돌
시스템 외부의 문제로 인해 시스템이 갑자기 중지되고 시스템이 충돌 할 수 있습니다. 예를 들어 전원 공급이 중단되면 기본 하드웨어 또는 소프트웨어 오류가 발생할 수 있습니다.
예를 들어 운영 체제 오류가 포함될 수 있습니다.
디스크 장애
기술 발전의 초기에는 하드 디스크 드라이브 또는 스토리지 드라이브가 자주 실패하는 일반적인 문제였습니다.
디스크 오류에는 불량 섹터 형성, 디스크에 연결할 수 없음, 디스크 헤드 충돌 또는 디스크 스토리지의 전체 또는 일부를 파괴하는 기타 오류가 포함됩니다.
저장 구조
이미 스토리지 시스템에 대해 설명했습니다. 간단히 말해서 스토리지 구조는 두 가지 범주로 나눌 수 있습니다.
Volatile storage− 이름에서 알 수 있듯이 휘발성 스토리지는 시스템 충돌에서 살아남을 수 없습니다. 휘발성 저장 장치는 CPU에 매우 가깝게 배치됩니다. 일반적으로 칩셋 자체에 내장되어 있습니다. 예를 들어, 주 메모리와 캐시 메모리는 휘발성 저장소의 예입니다. 빠르지 만 적은 양의 정보 만 저장할 수 있습니다.
Non-volatile storage− 이러한 메모리는 시스템 충돌에서 살아 남기 위해 만들어졌습니다. 데이터 저장 용량은 크지 만 접근성은 느립니다. 예를 들면 하드 디스크, 자기 테이프, 플래시 메모리 및 비 휘발성 (배터리 백업) RAM이 있습니다.
복구 및 원 자성
시스템이 충돌하면 여러 트랜잭션이 실행되고 데이터 항목을 수정하기 위해 다양한 파일이 열릴 수 있습니다. 트랜잭션은 본질적으로 원자적인 다양한 작업으로 이루어집니다. 그러나 DBMS의 ACID 속성에 따라 트랜잭션의 원자 성은 전체적으로 유지되어야합니다. 즉, 모든 작업이 실행되거나 실행되지 않습니다.
DBMS가 충돌에서 복구 될 때 다음을 유지해야합니다.
실행중인 모든 트랜잭션의 상태를 확인해야합니다.
트랜잭션이 일부 작업 중일 수 있습니다. 이 경우 DBMS는 트랜잭션의 원 자성을 보장해야합니다.
트랜잭션을 지금 완료 할 수 있는지 또는 롤백해야하는지 확인해야합니다.
어떤 트랜잭션도 DBMS를 일관성없는 상태로 남겨 둘 수 없습니다.
DBMS가 트랜잭션의 원 자성을 유지하고 복구하는 데 도움이되는 두 가지 유형의 기술이 있습니다.
각 트랜잭션의 로그를 유지하고 실제로 데이터베이스를 수정하기 전에 안정적인 저장소에 기록합니다.
휘발성 메모리에서 변경이 수행되고 나중에 실제 데이터베이스가 업데이트되는 섀도우 페이징을 유지합니다.
로그 기반 복구
로그는 트랜잭션에서 수행 한 작업의 기록을 유지하는 일련의 기록입니다. 실제 수정 전에 로그를 작성하고 안전한 저장 매체에 저장하는 것이 중요합니다.
로그 기반 복구는 다음과 같이 작동합니다-
로그 파일은 안정적인 저장 매체에 보관됩니다.
트랜잭션이 시스템에 들어가 실행을 시작하면 이에 대한 로그를 작성합니다.
<Tn, Start>
트랜잭션이 항목 X를 수정하면 다음과 같이 로그를 작성합니다.
<Tn, X, V1, V2>
T n 이 V 1 에서 V 2 로 X 값을 변경했습니다 .
- 트랜잭션이 완료되면 기록됩니다.
<Tn, commit>
데이터베이스는 두 가지 접근 방식을 사용하여 수정할 수 있습니다-
Deferred database modification − 모든 로그는 안정적인 저장소에 기록되고 트랜잭션이 커밋되면 데이터베이스가 업데이트됩니다.
Immediate database modification− 각 로그는 실제 데이터베이스 수정을 따릅니다. 즉, 데이터베이스는 모든 작업 후 즉시 수정됩니다.
동시 트랜잭션으로 복구
둘 이상의 트랜잭션이 병렬로 실행되는 경우 로그가 인터리브됩니다. 복구 시점에는 복구 시스템이 모든 로그를 역 추적 한 다음 복구를 시작하는 것이 어려워집니다. 이러한 상황을 완화하기 위해 대부분의 최신 DBMS는 '체크 포인트'개념을 사용합니다.
검문소
실시간 및 실제 환경에서 로그를 보관하고 유지하면 시스템에서 사용 가능한 모든 메모리 공간이 채워질 수 있습니다. 시간이 지남에 따라 로그 파일이 너무 커져서 전혀 처리 할 수 없습니다. 체크 포인트는 모든 이전 로그가 시스템에서 제거되고 스토리지 디스크에 영구적으로 저장되는 메커니즘입니다. 체크 포인트는 DBMS가 일관된 상태 였고 모든 트랜잭션이 커밋되기 전의 지점을 선언합니다.
회복
동시 트랜잭션이있는 시스템이 충돌 및 복구되면 다음과 같은 방식으로 작동합니다.
복구 시스템은 로그를 끝에서 마지막 체크 포인트까지 역방향으로 읽습니다.
실행 취소 목록과 다시 실행 목록의 두 목록을 유지합니다.
복구 시스템이 <T n , Start> 및 <T n , Commit> 또는 <T n , Commit> 만 포함 된 로그를 발견 하면 트랜잭션을 다시 실행 목록에 넣습니다.
복구 시스템에서 <T n , Start> 가 포함 된 로그를 보았지만 커밋 또는 중단 로그가 없으면 트랜잭션을 실행 취소 목록에 넣습니다.
그런 다음 실행 취소 목록의 모든 트랜잭션이 실행 취소되고 해당 로그가 제거됩니다. 다시 실행 목록 및 이전 로그의 모든 트랜잭션이 제거 된 다음 로그를 저장하기 전에 다시 실행됩니다.