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

적용 대상:SQL Server

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

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

참고

장기 실행 트랜잭션으로 인해 UNDO 시간이 과도하게 길어지는 경우 주어진 데이터베이스에 대해 대상 복구 시간 설정에 지정된 상한이 초과될 수 있습니다.

제한 사항

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

많은 수의 DML 작업을 수신하는 데이터베이스에서 간접 검사점을 사용하도록 설정하면 백그라운드 작성기는 복구 수행에 필요한 시간이 데이터베이스의 목표 복구 시간 집합 내에 있는지 확인하기 위해 더티 버퍼를 디스크로 적극적으로 플러시하기 시작할 수 있습니다. 이로 인해 특정 시스템에서 추가 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 { SECONDS | MINUTES }

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

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

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

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

    ALTER DATABASE AdventureWorks2022 SET TARGET_RECOVERY_TIME = 60 SECONDS;
    

참고 항목