API Gateway Canary 릴리스 배포 설정
Canary 릴리스
Canary 릴리스 배포에서 전체 API 트래픽은 사전 구성된 비율로 프로덕션 릴리스와 Canary 릴리스로 임의로 분할됩니다. 일반적으로 Canary 릴리스에는 API 트래픽 중 작은 백분율이 주어지며, 프로덕션 릴리스가 나머지를 차지합니다. 업데이트된 API 기능은 Canary를 통하는 API 트래픽에만 보입니다. 테스트 범위 또는 성능을 최적화하기 위해 Canary 트래픽 백분율을 조정할 수 있습니다.
Canary 트래픽을 적은 수준으로 유지하고 선택이 임의로 이루어지면 대부분의 사용자는 새 버전의 잠재적 버그로 인한 부정적 영향을 받지 않으며, 단일 사용자가 부정적 영향을 계속 받는 경우는 없습니다.
테스트 지표가 요구 사항을 통과한 후에는 Canary 릴리스를 프로덕션 릴리스로 승격하고 배포에서 Canary를 비활성화할 수 있습니다. 이렇게 하면 새 기능을 프로덕션 단계에서 사용할 수 있습니다.
API Gateway에서 Canary 릴리스 배포
API Gateway에서 Canary 릴리스 배포는 API 기본 버전의 프로덕션 릴리스를 위한 배포 단계를 사용하고, API의 기본 버전과 관련하여 새 버전에 대한 Canary 릴리스를 단계에 연결합니다. 이 단계는 초기 배포에 연결되고, Canary는 후속 배포에 연결됩니다. 처음에는 단계와 Canary 모두 동일한 API 버전을 가리킵니다. 이 단원에서는 단계와 프로덕션 릴리스를 구분하지 않고 사용하며, Canary와 Canary 릴리스를 구분하지 않고 사용합니다.
Canary 릴리스가 포함된 API를 배포하려면 일반 배포의 단계에 Canary 설정을 추가하여 Canary 릴리스 배포를 생성합니다. Canary 설정은 기본 Canary 릴리스를 설명하고, 단계는 이 배포 내의 API 프로덕션 릴리스를 나타냅니다. Canary 설정을 추가하려면 배포 단계에서 canarySettings
를 설정하고 다음을 지정하세요.
-
처음에는 단계에서 설정된 기본 버전 배포의 ID와 동일한 배포 ID.
-
Canary 릴리스의 API 트래픽 백분율(0.0~100.0%, 0.0%와 100.0% 포함).
-
프로덕션 릴리스 단계 변수를 재정의할 수 있는 Canary 릴리스의 단계 변수.
-
useStageCache가 설정되어 있고 API 캐싱이 단계에서 활성화된 경우, Canary 요청에 단계 캐시 사용.
Canary 릴리스가 활성화된 후에는 Canary 릴리스가 비활성화되고 단계에서 Canary 설정이 제거될 때까지 배포 단계를 다른 비Canary 릴리스 배포에 연결할 수 없습니다.
API 실행 로깅을 활성화하면 Canary 릴리스는 모든 Canary 요청에 대해 자체 로그와 지표를 생성합니다. 이 로그와 지표는 프로덕션 단계 CloudWatch Logs 로그 그룹뿐 아니라 Canary별 CloudWatch Logs 로그 그룹에도 보고됩니다. 액세스 로깅도 마찬가지입니다. 별도의 Canary별 로그는 새 API 변경의 유효성을 검사하여 변경을 수락해 Canary 릴리스를 프로덕션 단계로 승격하거나 변경을 취소하고 Canary 릴리스를 프로덕션 단계에서 되돌릴지 여부를 결정하는 데 유용합니다.
프로덕션 단계 실행 로그 그룹은 API-Gateway-Execution-Logs/
으로 명명되며, Canary 릴리스 실행 로그 그룹은 {rest-api-id}
/{stage-name}
API-Gateway-Execution-Logs/
로 명명됩니다. 액세스 로깅의 경우, 새 로그 그룹을 만들거나 기존 로그 그룹을 선택해야 합니다. Canary 릴리스 액세스 로그 그룹 이름은 선택한 로그 그룹 이름에 {rest-api-id}
/{stage-name}
/Canary/Canary
접미사가 추가됩니다.
Canary 릴리스는 단계 캐시(활성화한 경우)를 사용하여 응답을 저장하고, 사전 구성된 TTL(time-to-live) 기간 내에 캐시된 항목을 사용하여 다음 번 Canary 요청에 결과를 반환합니다.
Canary 릴리스 배포에서 API 트래픽의 프로덕션 릴리스와 Canary 릴리스는 같은 버전이나 서로 다른 버전에 연결할 수 있습니다. 프로덕션 릴리스와 Canary 릴리스가 서로 다른 버전에 연결된 경우, 프로덕션 요청의 응답과 Canary 요청의 응답은 별도로 캐시되며, 단계 캐시는 프로덕션 요청과 Canary 요청에 해당하는 결과를 반환합니다. 프로덕션 릴리스와 Canary 릴리스가 같은 배포에 연결된 경우, 단계 캐시는 두 가지 요청 유형에 단일 캐시 키를 사용하여 프로덕션 릴리스와 Canary 릴리스의 동일한 요청에 대해 동일한 응답을 반환합니다.