다음을 통해 공유


로그 시퀀스 번호로 복구(SQL Server)

이 항목에서는 전체 또는 대량 로그 복구 모델을 사용하는 데이터베이스와 관련된 내용을 다룹니다.

LSN(로그 시퀀스 번호)을 사용하여 복원 작업에 대한 복구 지점을 정의할 수 있습니다. 그러나 이 기능은 도구 공급업체를 위해 특별히 제작된 기능으로 일반적으로 유용한 기능은 아닙니다.

로그 시퀀스 번호 개요

LSN은 RESTORE 순서 중에 내부적으로 사용되어 데이터가 복원될 지정 시간을 추적합니다. 백업을 복구할 때 데이터는 백업이 이루어진 지정 시간에 해당하는 LSN으로 복원됩니다. 차등 및 로그 백업의 경우 데이터베이스는 보다 나중의 것으로 복원되며 이는 더 높은 LSN에 해당합니다.

트랜잭션 로그의 모든 레코드는 LSN(로그 시퀀스 번호)으로 고유하게 식별됩니다. LSN은 변경이 발생한 순서에 따라 번호가 매겨집니다. 예를 들어 LSN2가 LSN1보다 큰 경우 로그 레코드 LSN1에 해당하는 변경이 먼저 발생하고 로그 레코드 LSN2에 해당하는 변경이 이후에 발생한 것입니다.

중요한 이벤트가 발생한 로그 레코드의 LSN은 올바른 복원 시퀀스를 생성하는 데 도움이 될 수 있습니다. LSN은 정렬되기 때문에 같음 또는 같지 않음을 확인할 수 있습니다. 즉, <, >, =, <=, **>=**과 같은 비교가 가능합니다. 이러한 비교 방식은 복원 시퀀스를 만들 때 유용하게 사용할 수 있습니다.

[!참고]

LSN은 numeric(25,0) 데이터 형식의 값입니다. 더하기나 빼기와 같은 산술 연산은 의미가 없으며 LSN과 함께 사용하면 안 됩니다.

[맨 위]

백업과 복원에 사용된 LSN 보기

다음 중 하나 이상의 방법을 사용하여 지정된 백업 및 복원 이벤트가 발생했을 때의 로그 레코드 LSN을 볼 수 있습니다.

[!참고]

LSN은 일부 메시지 텍스트에도 나타납니다.

LSN으로 복원하기 위한 Transact-SQL 구문

RESTORE 문을 사용하여 다음과 같은 LSN에서 또는 이전에 즉시 중지할 수 있습니다.

  • WITH STOPATMARK = 'lsn:<lsn_number>' 절을 사용합니다. 여기서 lsn:<lsnNumber>는 지정한 LSN을 포함하는 로그 레코드가 복구 지점이 되도록 지정하는 문자열입니다.

    STOPATMARK는 복구 중지 지점을 나타내며 지정된 로그 레코드를 포함하는 지점까지 롤포워드됩니다.

  • WITH STOPBEFOREMARK = 'lsn:<lsn_number>' 절을 사용합니다. 여기서 lsn:<lsnNumber>는 지정한 LSN 번호가 포함된 로그 레코드 바로 앞의 로그 레코드가 복구 지점이 되도록 지정하는 문자열입니다.

    STOPBEFOREMARK는 LSN에 롤포워드하고 롤포워드의 해당 로그 레코드를 제외합니다.

일반적으로 특정 트랜잭션을 포함하거나 제외하도록 선택합니다. 필수는 아니지만 대개 지정된 로그 레코드는 트랜잭션 커밋 레코드입니다.

다음 예에서는 AdventureWorks 데이터베이스가 전체 복구 모델을 사용하도록 변경되었다고 가정합니다.

RESTORE LOG AdventureWorks FROM DISK = 'c:\adventureworks_log.bak' 
WITH STOPATMARK = 'lsn:15000000040000037'
GO

관련 태스크

참고 항목

참조

RESTORE(Transact-SQL)

개념

트랜잭션 로그 백업 적용(SQL Server)

트랜잭션 로그(SQL Server)