본문 바로가기
[AWS-DR]/ELB

[참고] Application Load Balancer 대상 그룹 (대상유형이 IP기반시 - 100.64.0.0 대역 사용 이유)

by METAVERSE STORY 2024. 5. 21.
반응형

 

 

 

Application Load Balancer 대상 그룹

대상 그룹은 지정한 프로토콜과 포트 번호를 사용하여 EC2 인스턴스 같은 개별 등록된 대상으로 요청을 라우팅합니다. 여러 대상 그룹에 대상을 등록할 수 있습니다. 대상 그룹 기준으로 상태 확인을 구성할 수 있습니다. 로드 밸런서의 리스너 규칙에서 지정한 대상 그룹에 등록된 모든 대상에서 상태 검사가 수행됩니다.

각 대상 그룹은 하나 이상의 등록된 대상에 요청을 라우팅하는 데 사용됩니다. 각 리스너 규칙을 생성할 때 대상 그룹 및 조건을 지정합니다. 규칙 조건이 충족되면 해당하는 대상 그룹으로 트래픽이 전달됩니다. 서로 다른 유형의 요청에 대해 서로 다른 대상 그룹을 생성할 수 있습니다. 예를 들어, 일반 요청인 경우 하나의 대상 그룹을 생성하고 애플리케이션에 대한 마이크로 서비스의 요청인 경우 다른 대상 그룹을 생성합니다. 하나의 로드 밸런서에만 각 대상 그룹을 사용할 수 있습니다. 자세한 내용은 Application Load Balancer 구성 요소 단원을 참조하십시오.

대상 그룹 기준으로 로드 밸런서에 대한 상태 확인 설정을 정의합니다. 대상 그룹을 만들거나 나중에 변경할 때 재정의하지 않는 이상 각 대상 그룹은 기본 상태 확인 설정을 사용합니다. 리스너에 대한 규칙에 대상 그룹을 지정한 후, 로드 밸런서는 해당 로드 밸런서에 대해 활성화된 가용 영역의 대상 그룹에 등록된 모든 대상의 상태를 지속적으로 모니터링합니다. 로드 밸런서는 정상 상태로 등록된 대상으로 요청을 라우팅합니다.

라우팅 구성

 

기본적으로 로드 밸런서는 대상 그룹을 생성할 때 지정한 프로토콜과 포트 번호를 사용하여 대상으로 요청을 라우팅합니다. 또는 대상 그룹에 등록할 때 대상으로 트래픽을 라우팅하는 데 사용되는 포트를 재정의할 수 있습니다.

대상 그룹은 다음과 같은 프로토콜 및 포트를 지원합니다.

  • 프로토콜: HTTP, HTTPS
  • 포트: 1-65535

대상 그룹이 HTTPS 프로토콜로 구성되거나 HTTPS 상태 확인을 사용하는 경우, 대상에 대한 TLS 연결은 ELBSecurityPolicy-2016-08 정책의 보안 설정을 사용합니다. 로드 밸런서는 대상에 설치된 인증서를 사용하여 대상과의 TLS 연결을 설정합니다. 로드 밸런서는 이러한 인증서를 검증하지 않습니다. 따라서 자체 서명된 인증서 또는 만료된 인증서를 사용할 수 있습니다. 로드 밸런서와 그 대상이 가상 사설 클라우드 (VPC) 에 있기 때문에 로드 밸런서와 대상 간의 트래픽은 패킷 수준에서 인증되므로 대상의 인증서가 유효하지 않더라도 공격이나 man-in-the-middle 스푸핑의 위험이 없습니다. 외부로 나가는 트래픽에는 이와 동일한 보호 기능이 적용되지 AWS 않으므로 트래픽을 더 안전하게 보호하려면 추가 조치가 필요할 수 있습니다.

대상 유형

 

대상 그룹을 생성할 때 대상 유형을 지정합니다. 이 값에 따라 이 대상 그룹에 대상을 등록할 때 지정하는 대상의 유형이 결정됩니다. 대상 그룹을 생성한 후에는 대상 유형을 변경할 수 없습니다.

가능한 대상 유형은 다음과 같습니다.

instance

대상이 인스턴스 ID에 의해 지정됩니다.

ip

대상이 IP 주소입니다.

lambda

대상이 Lambda 함수입니다.

 

대상 유형이 ip인 경우, 다음 CIDR 블록 중 하나에서 IP 주소를 지정할 수 있습니다.

  • 대상 그룹에 대한 VPC의 서브넷
  • 10.0.0.0/8(RFC 1918)
  • 100.64.0.0/10(RFC 6598)
  • 172.16.0.0/12(RFC 1918)
  • 192.168.0.0/16(RFC 1918)

 

중요

공개적으로 라우팅 가능한 IP 주소는 지정할 수 없습니다.

지원되는 모든 CIDR 블록을 사용하여 다음 대상을 대상 그룹에 등록할 수 있습니다.

  • 로드 밸런서 VPC(동일한 리전 또는 다른 리전)로 피어링된 VPC의 인스턴스.
  • IP 주소와 포트로 주소를 지정할 수 있는 AWS 리소스(예: 데이터베이스).
  • AWS Direct Connect 또는 Site-to-Site VPN 연결을 통해 AWS에 연결된 온프레미스 리소스.
참고

Local Zone 내에 배포된 Application Load Balancer의 경우 트래픽을 수신하려면 ip 대상이 동일한 로컬 영역에 있어야 합니다.

자세한 정보는 AWS Local Zone이 무엇인가요?을 참조하세요.

인스턴스 ID를 사용하여 대상을 지정하면 해당 인스턴스의 기본 네트워크 인터페이스에 지정된 기본 프라이빗 IP 주소를 사용하여 트래픽이 인스턴스로 라우팅됩니다. IP 주소를 사용하여 대상을 지정하면 하나 이상의 네트워크 인터페이스에서 프라이빗 IP 주소를 사용하여 트래픽을 인스턴스로 라우팅할 수 있습니다. 그러면 한 인스턴스의 여러 애플리케이션이 동일한 포트를 사용할 수 있습니다. 각 네트워크 인터페이스에는 자체 보안 그룹이 있을 수 있습니다.

대상 그룹의 대상 유형이 lambda인 경우 단일 Lambda 함수를 등록할 수 있습니다. 로드 밸런서가 Lambda 함수에 대한 요청을 수신하면 Lambda 함수를 호출합니다. 자세한 내용은 Lambda 함수를 대상으로 사용 단원을 참조하십시오.

Amazon Elastic Container Service(Amazon ECS)를 Application Load Balancer의 대상으로 구성할 수 있습니다. 자세한 내용은 Amazon Elastic Container Service 사용 설명서의 애플리케이션 로드 밸런서 생성을 참조하십시오. AWS Fargate

IP 주소 유형

 

새 대상 그룹 생성 시 대상 그룹의 IP 주소 유형을 선택할 수 있습니다. 이는 대상과 통신하고 상태를 확인하는 데 사용되는 IP 버전을 제어합니다.

Application Load Balancer는 IPv4 및 IPv6 대상 그룹을 모두 지원합니다. 기본 선택값은 IPv4입니다.

고려 사항
  • 하나의 대상 그룹 내의 모든 IP 주소는 IP 주소 유형이 동일해야 합니다. 예를 들어 IPv6 대상 그룹에 IPv4 대상을 등록할 수 없습니다.
  • IPv6 대상 그룹은 dualstack 로드 밸런서와 함께만 사용할 수 있습니다.
  • IPv6 대상 그룹은 IP 및 인스턴스 유형 대상을 지원합니다.

프로토콜 버전

 

기본적으로 Application Load Balancer는 HTTP/1.1을 사용하여 대상에 요청을 보냅니다. 프로토콜 버전을 사용하면 HTTP/2 또는 gRPC를 사용하여 대상에 요청을 보낼 수 있습니다.

다음 표에는 요청 프로토콜과 대상 그룹 프로토콜 버전의 조합에 대한 결과가 요약되어 있습니다.

요청 프로토콜프로토콜 버전결과
HTTP/1.1 HTTP/1.1 성공
HTTP/2 HTTP/1.1 성공
gRPC HTTP/1.1 오류
HTTP/1.1 HTTP/2 오류
HTTP/2 HTTP/2 성공
gRPC HTTP/2 대상이 gRPC를 지원하는 경우 성공
HTTP/1.1 gRPC 오류
HTTP/2 gRPC POST 요청 시 성공
gRPC gRPC 성공
gRPC 프로토콜 버전에 대한 고려 사항
  • 지원되는 유일한 리스너 프로토콜은 HTTPS입니다.
  • 리스너 규칙에 대해 지원되는 유일한 작업 유형은 forward입니다.
  • 지원되는 유일한 대상 유형은 instance  ip입니다.
  • 로드 밸런서는 gRPC 요청을 구문 분석하고 패키지, 서비스 및 메서드를 기반으로 gRPC 호출을 적절한 대상 그룹으로 라우팅합니다.
  • 로드 밸런서는 단항, 클라이언트 측 스트리밍, 서버 측 스트리밍, 양방향 스트리밍을 지원합니다.
  • 사용자 지정 상태 확인 방법을 /package.service/method 형식으로 제공해야 합니다.
  • 대상으로부터 응답 성공을 확인할 때 사용할 gRPC 상태 코드를 지정해야 합니다.
  • Lambda 함수를 대상으로 사용할 수 없습니다.
HTTP/2 프로토콜 버전에 대한 고려 사항
  • 지원되는 유일한 리스너 프로토콜은 HTTPS입니다.
  • 리스너 규칙에 대해 지원되는 유일한 작업 유형은 forward입니다.
  • 지원되는 유일한 대상 유형은 instance  ip입니다.
  • 로드 밸런서는 클라이언트에서 오는 스트리밍을 지원합니다. 로드 밸런서는 대상으로 가는 스트리밍을 지원하지 않습니다.

등록된 대상

 

로드 밸런서는 클라이언트에 대해 단일 접점의 역할을 하며 정상적으로 등록된 대상 간에 수신 트래픽을 자동으로 분산합니다. 하나 이상의 대상 그룹에 각 대상을 등록할 수 있습니다.

애플리케이션에 대한 요구가 증가하면 이를 처리하기 위해 하나 이상의 대상 그룹에 추가 대상을 등록할 수 있습니다. 로드 밸런서는 등록 프로세스가 완료되고 대상이 초기 상태 확인을 통과하자마자 새로 등록된 대상에 대한 라우팅 요청을 시작합니다.

애플리케이션에 대한 요구가 감소하거나 대상을 서비스해야 하는 경우에는 대상 그룹에서 대상 등록을 취소할 수 있습니다. 대상을 등록 취소하면 대상 그룹에서 제거되지만 대상에 영향을 미치지는 않습니다. 등록이 취소되는 즉시 로드 밸런서는 대상으로의 요청 라우팅을 중지합니다. 진행 중인 요청이 완료될 때까지 해당 대상은 draining 상태를 유지합니다. 요청 수신을 다시 시작할 준비가 되면 대상 그룹에 대상을 다시 등록할 수 있습니다.

인스턴스 ID로 대상을 등록하는 경우 Auto Scaling 그룹에 로드 밸런서를 사용할 수 있습니다. Auto Scaling 그룹에 대상 그룹을 연결하면 Auto Scaling은 대상을 시작할 때 대상 그룹에 해당 대상을 등록합니다. 자세한 내용은 Amazon EC2 Auto Scaling 사용 설명서에서 로드 밸런서를 Auto Scaling 그룹에 연결을 참조하세요.

Limits
  • 동일한 VPC에서 다른 Application Load Balancer의 IP 주소는 등록할 수 없습니다. 다른 Application Load Balancer가 로드 밸런서 VPC에 피어링된 VPC에 있는 경우 해당 IP 주소를 등록할 수 있습니다.
  • 로드 밸런서 VPC(동일한 리전 또는 다른 리전)로 피어링된 VPC의 인스턴스는 인스턴스 ID로 등록할 수 없습니다. 이러한 인스턴스는 IP 주소로 등록할 수 있습니다.

대상 그룹 속성

 

대상 그룹 유형이 instance 또는 ip인 경우 다음 대상 그룹 속성이 지원됩니다.

deregistration_delay.timeout_seconds

Elastic Load Balancing에서 대상을 등록 취소하기 전에 대기하는 시간. 범위는 0~3600초입니다. 기본 값은 300초입니다.

load_balancing.algorithm.type

로드 밸런싱 알고리즘은 요청을 라우팅할 때 로드 밸런서가 대상을 선택하는 방법을 결정합니다. 값은 round_robinleast_outstanding_requests, 또는 weighted_random 입니다. 기본값은 round_robin입니다.

load_balancing.algorithm.anomaly_mitigation

 load_balancing.algorithm.type 경우에만 사용할 수 weighted_random 있습니다. 예외 항목 완화가 활성화되었는지 여부를 나타냅니다. 값은 on 또는 off입니다. 기본값은 off입니다.

load_balancing.cross_zone.enabled

교차 영역 로드 밸런싱의 활성화 여부를 나타냅니다. 값은 true, false 또는 use_load_balancer_configuration입니다. 기본값은 use_load_balancer_configuration입니다.

slow_start.duration_seconds

로드 밸런서가 대상 그룹에 대해 선형으로 증가하는 트래픽 공유를 새로 등록된 대상에 보내는 시간(초 단위). 범위는 30~900초입니다(15분). 기본값은 0초입니다(비활성화).

stickiness.enabled

고정 세션을 활성화할지 여부를 나타냅니다. 값은 true 또는 false입니다. 기본값은 false입니다.

stickiness.app_cookie.cookie_name

애플리케이션 쿠키의 이름입니다. 애플리케이션 쿠키 이름에는 AWSALB, AWSALBAPP, 또는 AWSALBTG 접두사를 사용할 수 없습니다. 이 단어는 로드 밸런서에서 사용하도록 예약되어 있습니다.

stickiness.app_cookie.duration_seconds

애플리케이션 기반 쿠키 만료 기간(초)입니다. 이 기간이 지난 후 쿠키는 무효로 간주됩니다. 최소값은 1초이고 최대값은 7일(604800초)입니다. 기본값은 1일(86400초)입니다.

stickiness.lb_cookie.duration_seconds

기간 기반 쿠키 만료 기간(초)입니다. 이 기간이 지난 후 쿠키는 무효로 간주됩니다. 최소값은 1초이고 최대값은 7일(604800초)입니다. 기본값은 1일(86400초)입니다.

stickiness.type

고정의 유형. 가능한 값은 lb_cookie과 app_cookie입니다.

target_group_health.dns_failover.minimum_healthy_targets.count

정상 상태로 유지되어야 하는 최소 대상 수. 정상 대상 수가 이 값보다 낮으면 DNS에서 영역을 비정상으로 표시하여 트래픽이 정상 영역으로만 라우팅되도록 합니다. 가능한 값은 off 또는 1부터 최대 대상 수까지의 정수입니다. off, DNS 페일 어웨이가 비활성화되면 각 대상 그룹이 독립적으로 DNS 페일 오버에 기여합니다. 기본 값은 1입니다.

target_group_health.dns_failover.minimum_healthy_targets.percentage

정상 상태로 유지되어야 하는 대상의 최소 백분율. 정상 대상 백분율이 이 값보다 낮으면 DNS에서 영역을 비정상으로 표시하여 트래픽이 정상 영역으로만 라우팅되도록 합니다. 가능한 값은 off이거나 1부터 최대 대상 값 사이의 정수입니다. off, DNS 페일 어웨이가 비활성화되면 각 대상 그룹이 독립적으로 DNS 페일 오버에 기여합니다. 기본 값은 1입니다.

target_group_health.unhealthy_state_routing.minimum_healthy_targets.count

정상 상태로 유지되어야 하는 최소 대상 수. 정상 대상 수가 이 값보다 낮으면 비정상 대상을 포함한 모든 대상으로 트래픽을 전송합니다. 범위는 1에서 최대 대상 수까지입니다. 기본 값은 1입니다.

target_group_health.unhealthy_state_routing.minimum_healthy_targets.percentage

정상 상태로 유지되어야 하는 대상의 최소 백분율. 정상 대상의 백분율이 이 값보다 낮으면 비정상 대상을 포함한 모든 대상으로 트래픽을 전송합니다. 가능한 값은 off 또는 1부터 100까지의 정수입니다. 기본값은 off입니다.

대상 그룹 유형이 lambda인 경우 다음 대상 그룹 속성이 지원됩니다.

lambda.multi_value_headers.enabled

로드 밸런서와 Lambda 함수 간에 교환되는 요청 및 응답 헤더에 값 또는 문자열의 배열이 포함됩니다. 가능한 값은 true 또는 false입니다. 기본 값은 false입니다. 자세한 내용은 다중 값 헤더 단원을 참조하십시오.

라우팅 알고리즘

 

라우팅 알고리즘은 요청을 수신할 대상을 결정할 때 로드 밸런서에서 사용하는 방법입니다. 라운드 로빈 라우팅 알고리즘은 기본적으로 대상 그룹 수준에서 요청을 라우팅하는 데 사용됩니다. 애플리케이션의 요구 사항에 따라 가장 미해결 요청과 가중치가 적용된 임의 라우팅 알고리즘도 사용할 수 있습니다. 대상 그룹에는 한 번에 하나의 활성 라우팅 알고리즘만 있을 수 있지만 라우팅 알고리즘은 필요할 때마다 업데이트할 수 있습니다.

고정 세션을 활성화하면 선택한 라우팅 알고리즘이 초기 대상 선택에 사용됩니다. 동일한 클라이언트의 향후 요청은 선택한 라우팅 알고리즘을 우회하여 동일한 대상으로 전달됩니다.

라운드 로빈
  • 라운드 로빈 라우팅 알고리즘은 대상 그룹의 정상 대상 간에 요청을 순차적으로 균등하게 라우팅합니다.
  • 이 알고리즘은 일반적으로 받는 요청의 복잡성이 비슷하거나, 등록된 대상의 처리 능력이 비슷하거나, 요청을 대상 간에 균등하게 분배해야 하는 경우에 사용됩니다.
최소 미해결 요청
  • 가장 미해결 요청 라우팅 알고리즘은 진행 중인 요청 수가 가장 적은 대상으로 요청을 라우팅합니다.
  • 이 알고리즘은 일반적으로 수신되는 요청의 복잡성이 다양하고 등록된 대상의 처리 능력이 다를 때 사용됩니다.
  • HTTP/2를 지원하는 부하 분산기가 HTTP/1.1만 지원하는 대상을 사용하는 경우 요청을 여러 HTTP/1.1 요청으로 전환합니다. 이 구성에서 가장 미해결 요청 알고리즘은 각 HTTP/2 요청을 다중 요청으로 처리합니다.
  • 를 사용할 WebSockets 때는 미결 요청 알고리즘이 가장 적은 요청을 사용하여 대상을 선택합니다. 선택하면 로드 밸런서가 대상에 대한 연결을 생성하고 이 연결을 통해 모든 메시지를 보냅니다.
  • 가장 미해결 요청 라우팅 알고리즘은 슬로우 스타트 모드에서는 사용할 수 없습니다.
가중치 기반 랜덤
  • 가중치 무작위 라우팅 알고리즘은 대상 그룹의 정상 대상 간에 요청을 무작위 순서로 균등하게 라우팅합니다.
  • 이 알고리즘은 자동 목표 가중치 (ATW) 이상 현상 완화를 지원합니다.
  • 가중치 랜덤 라우팅 알고리즘은 슬로우 스타트 모드에서는 사용할 수 없습니다.

대상 그룹의 라우팅 알고리즘 수정

언제든지 대상 그룹의 라우팅 알고리즘을 수정할 수 있습니다.

 
  • New EC2 experience
  • Old EC2 experience
새 콘솔을 사용하여 라우팅 알고리즘을 수정하려면
  1. https://console.aws.amazon.com/ec2/에서 Amazon EC2 콘솔을 엽니다.
  2. 탐색 창의 Load Balancing 아래에서 대상 그룹을 선택합니다.
  3. 대상 그룹의 이름을 선택하여 세부 정보 페이지를 엽니다.
  4. 대상 그룹 세부 정보 페이지의 속성 탭에서 편집을 선택합니다.
  5. 대상 그룹 속성 편집 페이지의 트래픽 구성 섹션에 있는 로드 밸런싱 알고리즘에서 라운드 로빈, 미해결 요청 수 또는 가중치 기반 무작위를 선택합니다.
  6. [Save changes]를 선택합니다.

AWS CLI를 사용하여 라우팅 알고리즘을 수정하려면

modify-target-group-attributes명령을 속성과 함께 사용하십시오. load_balancing.algorithm.type

자동 목표 가중치 (ATW)

 

자동 목표 가중치 (ATW) 는 애플리케이션을 실행하는 대상을 지속적으로 모니터링하여 이상 현상이라고 하는 심각한 성능 편차를 감지합니다. ATW는 실시간 데이터 이상 탐지를 통해 타겟으로 라우팅되는 트래픽의 양을 동적으로 조정할 수 있는 기능을 제공합니다.

자동 목표 가중치 (ATW) 는 계정의 모든 Application Load Balancer에서 이상 항목 탐지를 자동으로 수행합니다. 변칙 대상이 식별되면 ATW는 라우팅되는 트래픽의 양을 줄임으로써 자동으로 대상을 안정화하려고 시도합니다. 이를 이상 완화라고 합니다. ATW는 트래픽 분배를 지속적으로 최적화하여 타겟 그룹 실패율을 최소화하는 동시에 타겟별 성공률을 극대화합니다.

고려 사항:
  • 현재 이상 탐지는 대상에서 오는 HTTP 5xx 응답 코드 및 대상으로의 연결 장애를 모니터링합니다. 이상 탐지는 항상 켜져 있으며 끌 수 없습니다.
  • Lambda를 타겟으로 사용할 때는 ATW가 지원되지 않습니다.

이상 탐지

ATW 이상 탐지는 대상 그룹의 다른 대상과 동작에서 상당한 편차를 보이는 대상을 모니터링합니다. 이상 현상이라고 하는 이러한 편차는 한 대상의 오류 백분율을 대상 그룹 내 다른 대상의 오류 백분율과 비교하여 결정됩니다. 이러한 오류는 연결 오류일 수도 있고 HTTP 오류 코드일 수도 있습니다. 그러면 상대방보다 훨씬 높은 수치를 보고하는 대상은 변칙적인 것으로 간주됩니다.

이상 징후를 탐지하려면 대상 그룹에 최소 세 개의 정상 표적이 있어야 합니다. 대상이 대상 그룹에 등록된 경우 먼저 상태 확인을 통과해야 트래픽 수신을 시작할 수 있습니다. 대상이 대상을 수신하면 ATW는 대상 모니터링을 시작하고 이상 결과를 지속적으로 게시합니다. 이상이 없는 대상의 경우 예외 결과는 다음과 같습니다. normal 이상이 있는 대상의 경우 예외 결과는 다음과 같습니다. anomalous

ATW 이상 탐지는 대상 그룹 상태 확인과 독립적으로 작동합니다. 대상은 모든 대상 그룹 상태 검사를 통과할 수 있지만 오류율이 높아져 여전히 비정상 상태로 표시될 수 있습니다. 대상이 변칙 상태가 되어도 대상 그룹 상태 점검 상태에는 영향을 주지 않습니다.

이상 탐지 상태

ATW는 표적에 대해 수행하는 이상 탐지 상태를 지속적으로 게시합니다. OR를 사용하여 언제든지 현재 상태를 볼 수 있습니다. AWS Management Console AWS CLI

콘솔을 사용하여 이상 탐지 상태를 보려면:
  1. https://console.aws.amazon.com/ec2/에서 Amazon EC2 콘솔을 엽니다.
  2. 탐색 창의 Load Balancing 아래에서 대상 그룹을 선택합니다.
  3. 대상 그룹의 이름을 선택하여 세부 정보 페이지를 엽니다.
  4. 대상 그룹 세부 정보 페이지에서 대상 탭을 선택합니다.
  5. 등록된 대상 테이블의 예외 항목 탐지 결과 열에서 각 대상의 예외 항목 상태를 볼 수 있습니다.이상이 감지된 경우 결과는 다음과 같습니다. anomalous
  6. 이상 징후가 발견되지 않은 경우 결과는 다음과 같습니다. normal

를 사용하여 이상 탐지 결과를 보려면 AWS CLI

Include.member.N속성 값을 로 설정한 상태로 describe-target-health명령을 사용합니다. AnomalyDetection

예외 항목 완화

중요

ATW의 예외 항목 완화 기능은 가중치 랜덤 라우팅 알고리즘을 사용할 때만 사용할 수 있습니다.

ATW 변칙 완화 기능은 트래픽을 자동으로 변칙 대상으로부터 멀어지게 하여 공격 대상을 복구할 기회를 제공합니다.

완화 기간 중:
  • ATW는 비정상적인 대상으로 라우팅되는 트래픽의 양을 주기적으로 조정합니다. 현재 이 주기는 5초마다 입니다.
  • ATW는 변칙 대상으로 라우팅되는 트래픽의 양을 예외 항목 완화에 필요한 최소량으로 줄입니다.
  • 더 이상 변칙으로 감지되지 않는 대상은 대상 그룹의 다른 정상 대상과 동등한 수준에 도달할 때까지 점점 더 많은 트래픽이 해당 대상으로 라우팅됩니다.

ATW 변칙 완화 기능을 켜십시오.

언제든지 예외 항목 완화를 켤 수 있습니다.

예외 항목 완화를 켜려면:
  1. https://console.aws.amazon.com/ec2/에서 Amazon EC2 콘솔을 엽니다.
  2. 탐색 창의 Load Balancing 아래에서 대상 그룹을 선택합니다.
  3. 대상 그룹의 이름을 선택하여 세부 정보 페이지를 엽니다.
  4. 대상 그룹 세부 정보 페이지의 속성 탭에서 편집을 선택합니다.
  5. 대상 그룹 속성 편집 페이지의 트래픽 구성 섹션에서 로드 밸런싱 알고리즘에서 가중치 무작위가 선택되어 있는지 확인합니다.
  6. 참고: 가중치 무작위 알고리즘을 처음 선택하면 예외 항목 탐지가 기본적으로 켜집니다.
  7. 예외 항목 완화에서 예외 항목 완화 켜기가 선택되어 있는지 확인하십시오.
  8. 변경 사항 저장을 선택합니다.

다음을 사용하여 예외 항목 완화를 활성화하려면 AWS CLI

modify-target-group-attributes명령을 속성과 함께 사용하십시오. load_balancing.algorithm.anomaly_mitigation

예외 항목 완화 상태

ATW가 대상에 대해 완화를 수행할 때마다 OR를 사용하여 언제든지 현재 상태를 볼 수 있습니다. AWS Management Console AWS CLI

콘솔을 사용하여 이상 완화 상태를 보려면:
  1. https://console.aws.amazon.com/ec2/에서 Amazon EC2 콘솔을 엽니다.
  2. 탐색 창의 Load Balancing 아래에서 대상 그룹을 선택합니다.
  3. 대상 그룹의 이름을 선택하여 세부 정보 페이지를 엽니다.
  4. 대상 그룹 세부 정보 페이지에서 대상 탭을 선택합니다.
  5. 등록된 대상 테이블의 완화 적용 중 열에서 각 대상의 예외 항목 완화 상태를 볼 수 있습니다.완화 작업이 진행 중인 경우 상태는 입니다. no
  6. 완화가 진행 중이 아닌 경우 상태는 입니다. yes

를 사용하여 이상 완화 상태를 보려면 AWS CLI

Include.member.N속성 값이 로 설정된 상태에서 describe-target-health명령을 사용합니다. AnomalyDetection

등록 취소 지연

 

Elastic Load Balancing은 등록 취소 중인 대상으로 요청을 전송하는 것을 중지합니다. 기본적으로 Elastic Load Balancing은 등록 취소 프로세스를 완료하기 전에 300초 동안 대기하는데, 이는 대상에 대해 진행 중인 요청을 완료하는 데 도움이 될 수 있습니다. Elastic Load Balancing이 대기하는 시간을 변경하려면 등록 취소 지연 값을 업데이트합니다.

등록 취소하는 대상의 초기 상태는 draining입니다. 등록 취소 지연이 경과한 후 등록 취소 프로세스가 완료되며 대상 상태는 unused입니다. 대상이 Auto Scaling 그룹의 일부인 경우 종료 및 대체될 수 있습니다.

등록을 취소하는 대상에 진행 중인 요청이 없고 활성 연결이 없는 경우 Elastic Load Balancing은 등록 취소 지연 시간이 경과할 때까지 대기하지 않고 등록 취소 프로세스를 즉시 완료합니다. 하지만 대상 등록 취소가 완료되더라도 대상 상태는 등록 취소 지연 제한 시간이 초과될 때까지 draining으로 표시됩니다. 제한 시간이 초과되면 대상은 unused 상태로 전환됩니다.

등록 취소 지연이 경과되기 전에 등록을 취소하는 대상이 연결을 종료하면 클라이언트는 500 레벨 오류 응답을 수신합니다.

 
  • New EC2 experience
  • Old EC2 experience
새로운 EC2를 사용하여 등록 취소 지연 값을 업데이트하려면
  1. https://console.aws.amazon.com/ec2/에서 Amazon EC2 콘솔을 엽니다.
  2. 탐색 창의 LOAD BALANCING 아래에서 대상 그룹을 선택합니다.
  3. 대상 그룹의 이름을 선택하여 세부 정보 페이지를 엽니다.
  4. 그룹 세부 정보 탭의 속성 섹션에서 편집을 선택합니다.
  5. 속성 편집 페이지에서 필요에 따라 등록 취소 지연 값을 변경합니다.
  6. 변경 사항 저장을 선택합니다.

AWS CLI를 사용하여 등록 취소 지연 값을 업데이트하려면

modify-target-group-attributes명령을 deregistration_delay.timeout_seconds 속성과 함께 사용합니다.

느린 시작 모드

 

기본적으로, 대상은 대상 그룹으로 등록되자 마자 전체 요청 공유를 받기 시작하고 초기 상태 확인을 전달합니다. 느린 시작 모드를 사용하면 로드 밸런서가 대상으로 전체 요청 공유를 보내기 전에 대상에 워밍업 시간이 제공됩니다.

대상 그룹에 대해 느린 시작을 활성화한 후 대상 그룹이 정상으로 간주하면 해당 대상이 느린 시작 모드로 들어갑니다. 느린 시작 모드의 대상은 구성된 느린 시작 기간이 경과하거나 대상이 비정상 상태가 되면 느린 시작 모드를 종료합니다. 느린 시작 모드에서는 로드 밸런서가 대상으로 보낼 수 있는 요청의 수를 선형으로 증가시킵니다. 정상 대상이 느린 시작 모드를 종료한 후에는 로드 밸런서가 대상으로 전체 요청 공유를 보낼 수 있습니다.

고려 사항
  • 대상 그룹을 위해 느린 시작을 활성화하면, 대상 그룹으로 이미 등록된 정상 대상은 느린 시작 모드를 시작하지 않습니다.
  • 비어있는 대상 그룹을 위해 느린 시작을 활성화한 다음 단일 등록 작업을 사용하여 대상을 등록하면, 이러한 대상들은 느린 시작 모드를 시작하지 않습니다. 느린 시작 모드 상태가 아닌 정상 대상이 최소한 하나 이상 있는 경우에만 새로 등록된 대상이 느린 시작 모드를 시작합니다.
  • 느린 시작 모드에서 대상을 등록 취소하는 경우 대상이 느린 시작 모드를 종료합니다. 동일한 대상을 다시 등록할 경우 대상 그룹이 정상으로 간주하면 느린 시작 모드로 전환됩니다.
  • 느린 시작 모드의 대상이 비정상 상태가 되면 대상이 느린 시작 모드를 종료합니다. 대상이 정상 상태가 되면 다시 느린 시작 모드로 전환됩니다.
  • 미해결 요청이 가장 적거나 가중치가 적용된 임의 라우팅 알고리즘을 사용할 때는 슬로우 스타트 모드를 활성화할 수 없습니다.
 
  • New EC2 experience
  • Old EC2 experience
새로운 EC2를 사용하여 느린 시작 지속시간 값을 업데이트하려면
  1. https://console.aws.amazon.com/ec2/에서 Amazon EC2 콘솔을 엽니다.
  2. 탐색 창의 LOAD BALANCING 아래에서 대상 그룹을 선택합니다.
  3. 대상 그룹의 이름을 선택하여 세부 정보 페이지를 엽니다.
  4. 그룹 세부 정보 탭의 속성 섹션에서 편집을 선택합니다.
  5. 속성 편집 페이지에서 필요에 따라 느린 시작 기간의 값을 변경합니다. 느린 시작 모드를 비활성화하려면 지속시간을 0으로 설정합니다.
  6. 변경 사항 저장을 선택합니다.

AWS CLI를 사용하여 느린 시작 지속시간 값을 업데이트하려면

modify-target-group-attributes명령을 slow_start.duration_seconds 속성과 함께 사용하십시오.

 

 

 

 

Application Load Balancer 대상 그룹 - Elastic Load Balancing (amazon.com)

 

Application Load Balancer 대상 그룹 - Elastic Load Balancing

ATW의 예외 항목 완화 기능은 가중치 랜덤 라우팅 알고리즘을 사용할 때만 사용할 수 있습니다.

docs.aws.amazon.com

 

반응형

댓글