Application Load Balancer에 대한 영역 전환
영역 전환 및 영역 자동 전환 기능은 Amazon Application Recovery Controller(ARC)의 기능입니다. 영역 전환을 사용하면 한 번의 작업으로 손상된 가용 영역에서 트래픽을 다른 곳으로 이동할 수 있습니다. 이러한 방법을 통해 AWS 리전의 다른 정상 가용 영역에서 계속 운영할 수 있습니다.
영역 자동 전환을 사용하면 이벤트 발생 시 사용자 대신 애플리케이션의 리소스 트래픽을 가용 영역에서 다른 곳으로 이동시켜 복구 시간을 단축하도록 AWS에 권한을 부여하게 됩니다. 내부 모니터링 결과 고객에게 잠재적으로 영향을 미칠 수 있는 가용 영역 장애가 있는 것으로 확인되면 AWS가 자동 전환을 시작합니다. AWS가 자동 전환을 시작하면 영역 자동 전환을 구성한 리소스로 향하는 애플리케이션 트래픽이 가용 영역에서 다른 곳으로 이동하기 시작합니다.
영역 전환을 시작하면 로드 밸런서가 해당 리소스에 대한 새 트래픽을 영향을 받는 가용 영역으로 보내는 것을 중단합니다. ARC는 영역 전환을 즉시 생성합니다. 그러나 클라이언트 동작과 연결 재사용에 따라 가용 영역에서 진행 중인 기존 연결이 완료되는 데 다소 시간이 걸릴 수 있습니다. DNS 설정 및 기타 요인에 따라 기존 연결이 몇 분 만에 완료되거나 더 오래 걸릴 수 있습니다. 자세한 내용은 Amazon Application Recovery Controller(ARC) 개발자 안내서의 클라이언트가 엔드포인트에 연결된 상태를 유지하는 시간 제한을 참조하세요.
영역 전환을 시작하기 전 준비 사항
-
영역 전환은 기본적으로 비활성화되어 있으며 각 Application Load Balancer에 대해 활성화해야 합니다. 자세한 내용은 Application Load Balancer에 대한 영역 전환 활성화 섹션을 참조하세요.
-
특정 로드 밸런서에 대한 영역 전환은 단일 가용 영역에 대해서만 시작할 수 있습니다. 여러 가용 영역에 대한 영역 전환은 시작할 수 없습니다.
-
AWS은(는) 여러 인프라 문제가 서비스에 영향을 미치는 경우 DNS에서 영역 로드 밸런서 IP 주소를 사전에 제거합니다. 영역 전환을 시작하기 전에 항상 현재 가용 영역 용량을 확인하세요. 로드 밸런서의 교차 영역 로드 밸런싱이 꺼져 있으며 영역 전환을 사용하여 영역 로드 밸런서 IP 주소를 제거하는 경우, 영역 전환의 영향을 받는 가용 영역도 대상 용량을 잃게 됩니다.
자세한 내용은 Amazon Application Recovery Controller(ARC) 개발자 가이드에서 ARC의 영역 전환 모범 사례를 참조하세요.
교차 영역 로드 밸런싱
교차 영역 로드 밸런싱이 활성화된 Application Load Balancer에서 영역 전환이 시작되면 대상에 대한 모든 트래픽이 영향을 받는 가용 영역에서 차단되고 영역 IP 주소가 DNS에서 제거됩니다.
이점:
-
가용 영역 장애로부터 더 빠르게 복구할 수 있습니다.
-
가용 영역에서 장애가 감지되면 트래픽을 정상 가용 영역으로 이동할 수 있습니다.
-
예상치 못한 가동 중지 시간을 방지하기 위해 장애를 시뮬레이션하고 식별하여 애플리케이션 무결성을 테스트할 수 있습니다.
영역 전환 관리 재정의
Application Load Balancer에 속하는 대상에 TargetHealth 상태와 독립된 새로운 AdministrativeOverride 상태가 포함됩니다.
Application Load Balancer의 영역 전환이 시작되면 전환 중인 영역 내의 모든 대상이 관리 재정의된 것으로 간주됩니다. Application Load Balancer는 관리적으로 재정의된 대상에 새로운 트래픽을 라우팅하지 않습니다. 기존 연결은 유기적으로 닫힐 때까지 그대로 유지됩니다.
가능한 AdministrativeOverride 상태는 다음과 같습니다.
- unknown
-
내부 오류로 인해 상태를 전파할 수 없습니다.
- no_override
-
대상에 대해 현재 활성 상태인 재정의가 없습니다.
- zonal_shift_active
-
대상 가용 영역에서 영역 전환이 활성 상태입니다.