다음을 통해 공유


데이터베이스의 대상 복구 시간 변경(SQL Server)

적용 대상:SQL Server

이 문서에서는 SQL Server Management Studio 또는 Transact-SQL을 사용하여 SQL Server에서 데이터베이스의 목표 복구 시간을 설정 또는 변경하는 방법을 알아봅니다. 기본적으로 대상 복구 시간은 60초이고, 데이터베이스에서는 간접 검사점을 사용합니다. 대상 복구 시간은 이 데이터베이스의 복구 시간에 상한을 설정합니다.

이 설정은 즉시 적용되며 SQL Server를 다시 시작할 필요가 없습니다.

참고

장시간 실행되는 트랜잭션이 과도한 UNDO 시간을 초래하면, 지정된 복구 시간 설정에 따른 데이터베이스 상한값을 초과할 수 있습니다.

제한

간접 검사점이 구성된 데이터베이스의 온라인 트랜잭션 작업으로 인해 성능이 저하될 수 있습니다. 간접 검사점은 데이터베이스 복구가 대상 복구 시간 내에 완료되도록 더티 페이지 수가 특정 임계값 미만인지 확인합니다. 복구 간격 구성 옵션은 더티 페이지 수를 사용하는 간접 검사점과 달리 트랜잭션 수를 사용하여 복구 시간을 결정합니다.

더티 페이지를 발생시키는 많은 수의 작업을 수신하는 데이터베이스에서 간접 검사점을 사용하도록 설정하면 백그라운드 기록기가 더티 버퍼를 디스크에 적극적으로 플러시하여 복구를 수행하는 데 필요한 시간이 데이터베이스에 설정된 대상 복구 시간 내에 있는지 확인할 수 있습니다. 이로 인해 특정 시스템에서 추가 I/O 작업이 발생할 수 있으며, 디스크 하위 시스템이 I/O 임계값을 초과하거나 그 근처에서 작동하는 경우 성능 병목 현상이 발생할 수 있습니다.

사용 권한

데이터베이스에 대한 ALTER 권한이 필요합니다.

SQL Server Management Studio 사용

  1. 개체 탐색기에서 SQL Server 데이터베이스 엔진의 인스턴스에 연결하고 해당 인스턴스를 확장합니다.

  2. 데이터베이스 컨테이너를 펼친 다음, 변경할 데이터베이스를 마우스 오른쪽 단추로 클릭하고 속성 명령을 선택합니다.

  3. 데이터베이스 속성 대화 상자에서 옵션 페이지를 선택합니다.

  4. 복구 패널의 대상 복구 시간(초) 필드에서 이 데이터베이스에 대한 복구 시간의 상한으로 원하는 시간(초)을 지정합니다.

Transact-SQL 사용

  1. 데이터베이스가 있는 SQL Server 인스턴스에 연결합니다.

  2. 다음 ALTER DATABASE 문을 다음과 같이 사용합니다.

    TARGET_RECOVERY_TIME = target_recovery_time { 초 | 분 }

    • 대상 복구 시간

      SQL Server 2016(13.x)부터 기본값은 1분입니다. 0(이전 버전의 기본값)보다 큰 경우 충돌 발생 시 지정된 데이터베이스에 대한 복구 시간의 상한을 지정합니다.

    • target_recovery_time 이 초 단위로 표현됨을 나타냅니다.

    • target_recovery_time 이 분 단위로 표현됨을 나타냅니다.

    다음 예에서는 AdventureWorks2022 데이터베이스의 대상 복구 시간을 60 초로 설정합니다.

    ALTER DATABASE AdventureWorks2022
    SET TARGET_RECOVERY_TIME = 60 SECONDS;