유연한 장애 조치(failover) 정책을 구성하여 자동 장애 조치의 상태 제어(AlwaysOn 가용성 그룹)
이 항목에서는 SQL Server 2012에서 Transact-SQL 또는 PowerShell을 사용하여 AlwaysOn 가용성 그룹에 대해 유연한 장애 조치(failover) 정책을 구성하는 방법에 대해 설명합니다. 유연한 장애 조치(failover) 정책을 통해 가용성 그룹에 대해 자동 장애 조치를 수행해야 하는 상태를 세부적으로 제어할 수 있습니다. 자동 장애 조치를 트리거하는 오류 상태 및 상태 확인 빈도를 변경하여 자동 장애 조치가 수행될 가능성을 높이거나 줄임으로써 고가용성에 대한 SLA를 지원할 수 있습니다.
시작하기 전 주의 사항
자동 장애 조치에 대한 제한 사항
사전 요구 사항
보안
다음을 사용하여 유연한 장애 조치(failover) 정책을 구성하려면:
Transact-SQL
PowerShell
[!참고]
SQL Server Management Studio를 통해서는 가용성 그룹의 유연한 장애 조치(failover) 정책을 구성할 수 없습니다.
시작하기 전 주의 사항
자동 장애 조치에 대한 제한 사항
자동 장애 조치가 발생하려면 현재 주 복제본과 하나의 보조 복제본을 자동 장애 조치를 사용하는 동기-커밋 가용성 모드용으로 구성하고 보조 복제본을 주 복제본과 동기화해야 합니다.
가용성 그룹이 해당 WSFC 오류 임계값을 초과하면 WSFC 클러스터가 가용성 그룹에 대해 자동 장애 조치를 시도하지 않습니다. 또한 클러스터 관리자가 실패한 리소스 그룹을 수동으로 온라인 상태로 만들거나 데이터베이스 관리자가 가용성 그룹의 수동 장애 조치를 수행할 때까지 가용성 그룹의 WSFC 리소스 그룹이 실패한 상태로 유지됩니다. WSFC 오류 임계값은 특정 기간 동안 가용성 그룹에 대해 지원되는 최대 오류 수로 정의됩니다. 기본 기간은 6시간이며, 이 기간 동안의 최대 오류 수에 대한 기본값은 n-1입니다. 여기서 n은 WSFC 노드의 수입니다. 지정된 가용성 그룹에 대한 오류-임계값 값을 변경하려면 WSFC 장애 조치(Failover) 관리자 콘솔을 사용하십시오.
사전 요구 사항
- 주 복제본을 호스팅하는 서버 인스턴스에 연결되어 있어야 합니다.
보안
사용 권한
태스크 |
사용 권한 |
---|---|
새로운 가용성 그룹에 대해 유연한 장애 조치(failover) 정책을 구성하려면 |
CREATE AVAILABILITY GROUP 서버 권한, ALTER ANY AVAILABILITY GROUP 권한, CONTROL SERVER 권한 중 하나와 sysadmin 고정 서버 역할의 멤버 자격이 필요합니다. |
기존 가용성 그룹의 정책을 수정하려면 |
가용성 그룹에 대한 ALTER AVAILABILITY GROUP 권한, CONTROL AVAILABILITY GROUP 권한, ALTER ANY AVAILABILITY GROUP 권한 또는 CONTROL SERVER 권한이 필요합니다. |
[맨 위]
Transact-SQL 사용
유연한 장애 조치(failover) 정책을 구성하려면
주 복제본을 호스팅하는 서버 인스턴스에 연결합니다.
새 가용성 그룹을 만들려는 경우 CREATE AVAILABILITY GROUP Transact-SQL 문을 사용합니다. 기존 가용성 그룹을 수정하려는 경우 ALTER AVAILABILITY GROUP Transact-SQL 문을 사용합니다.
장애 조치 상태 수준을 설정하려면 FAILURE_CONDITION_LEVEL = n 옵션을 사용합니다. 여기서 n은 1부터 5까지의 정수입니다.
예를 들어 다음 Transact-SQL 문은 기존 가용성 그룹 AG1의 오류 상태 수준을 수준 1로 변경합니다.
ALTER AVAILABILITY GROUP AG1 SET (FAILURE_CONDITION_LEVEL = 1);
각 정수 값과 오류 상태 수준의 관계는 다음과 같습니다.
Transact-SQL 값
수준
자동 장애 조치가 시작되는 경우
1
1
서버 작동 중지 시. 장애 조치나 재시작으로 인해 SQL Server 서비스가 중지된 경우
2
2
서버 응답 없음 발생 시. 낮은 값의 조건이 모두 충족되거나, SQL Server 서비스가 클러스터에 연결되었지만 상태 확인 제한 시간 임계값을 초과했거나, 현재 주 복제본이 오류 상태인 경우
3
3
중대 서버 오류 발생 시. 낮은 값의 조건이 모두 충족되거나 내부 중대 서버 오류가 발생한 경우
이 값은 기본 수준입니다.
4
4
일반 서버 오류 발생 시. 낮은 값의 조건이 모두 충족되거나 일반 서버 오류가 발생한 경우
5
5
지정된 오류 상태 발생 시. 낮은 값의 조건이 모두 충족되거나 지정된 오류 상태가 발생한 경우
장애 조치 상태 수준에 대한 자세한 내용은 가용성 그룹 자동 장애 조치에 대한 유연한 장애 조치(Failover) 정책(SQL Server)을 참조하십시오.
상태 확인 제한 시간 임계값을 구성하려면 HEALTH_CHECK_TIMEOUT = n 옵션을 사용합니다. 여기서 n은 15000밀리초(15초)부터 4294967295밀리초까지의 정수입니다. 기본값은 30000밀리초(30초)입니다.
예를 들어 다음 Transact-SQL 문은 기존 가용성 그룹 AG1의 상태 확인 제한 시간 임계값을 60,000밀리초(1분)로 변경합니다.
ALTER AVAILABILITY GROUP AG1 SET (HEALTH_CHECK_TIMEOUT = 60000);
[맨 위]
PowerShell 사용
유연한 장애 조치(failover) 정책을 구성하려면
기본값(cd)을 주 복제본을 호스팅하는 서버 인스턴스로 설정합니다.
가용성 그룹에 가용성 복제본을 추가하는 경우 New-SqlAvailabilityGroup cmdlet을 사용합니다. 기존 가용성 복제본을 수정하는 경우 Set-SqlAvailabilityGroup cmdlet을 사용합니다.
장애 조치 상태 수준을 설정하려면 FailureConditionLevel level 매개 변수를 사용합니다. 여기서 level은 다음 값 중 하나입니다.
값
수준
자동 장애 조치가 시작되는 경우
OnServerDown
1
서버 작동 중지 시. 장애 조치나 재시작으로 인해 SQL Server 서비스가 중지된 경우
OnServerUnresponsive
2
서버 응답 없음 발생 시. 낮은 값의 조건이 모두 충족되거나, SQL Server 서비스가 클러스터에 연결되었지만 상태 확인 제한 시간 임계값을 초과했거나, 현재 주 복제본이 오류 상태인 경우
OnCriticalServerError
3
중대 서버 오류 발생 시. 낮은 값의 조건이 모두 충족되거나 내부 중대 서버 오류가 발생한 경우
이 값은 기본 수준입니다.
OnModerateServerError
4
일반 서버 오류 발생 시. 낮은 값의 조건이 모두 충족되거나 일반 서버 오류가 발생한 경우
OnAnyQualifiedFailureConditions
5
지정된 오류 상태 발생 시. 낮은 값의 조건이 모두 충족되거나 지정된 오류 상태가 발생한 경우
장애 조치 상태 수준에 대한 자세한 내용은 가용성 그룹 자동 장애 조치에 대한 유연한 장애 조치(Failover) 정책(SQL Server)을 참조하십시오.
예를 들어 다음 명령은 기존 가용성 그룹 AG1의 오류 상태 수준을 수준 1로 변경합니다.
Set-SqlAvailabilityGroup ` -Path SQLSERVER:\Sql\PrimaryServer\InstanceName\AvailabilityGroups\MyAg ` -FailureConditionLevel OnServerDown
상태 확인 제한 시간 임계값을 설정하려면 HealthCheckTimeout n 매개 변수를 사용합니다. 여기서 n은 15000밀리초(15초)부터 4294967295밀리초까지의 정수입니다. 기본값은 30000밀리초(30초)입니다.
예를 들어 다음 명령은 기존 가용성 그룹 AG1의 상태 확인 제한 시간 임계값을 120,000밀리초(2분)로 변경합니다.
Set-SqlAvailabilityGroup ` -Path SQLSERVER:\Sql\PrimaryServer\InstanceName\AvailabilityGroups\MyAG ` -HealthCheckTimeout 120000
[!참고]
cmdlet의 구문을 보려면 SQL Server PowerShell 환경에서 Get-Help cmdlet을 사용합니다. 자세한 내용은 SQL Server PowerShell 도움말 보기을 참조하십시오.
SQL Server PowerShell 공급자를 설정하고 사용하려면
[맨 위]
참고 항목
참조
sp_server_diagnostics(Transact-SQL)
개념
AlwaysOn 가용성 그룹 개요(SQL Server)
장애 조치(Failover) 및 장애 조치(Failover) 모드(AlwaysOn 가용성 그룹)