DynamoDB-오류 처리

요청 처리에 실패하면 DynamoDB에서 오류가 발생합니다. 각 오류는 HTTP 상태 코드, 예외 이름 및 메시지 구성 요소로 구성됩니다. 오류 관리는 오류를 전파하는 SDK 또는 자체 코드에 있습니다.

코드 및 메시지

예외는 다른 HTTP 헤더 상태 코드에 속합니다. 4xx 및 5xx는 요청 문제 및 AWS와 관련된 오류를 보유합니다.

HTTP 4xx 범주의 예외는 다음과 같습니다.

  • AccessDeniedException − 클라이언트가 요청에 올바르게 서명하지 못했습니다.

  • ConditionalCheckFailedException − 거짓으로 평가 된 조건.

  • IncompleteSignatureException − 요청에 불완전한 서명이 포함되었습니다.

HTTP 5xx 범주의 예외는 다음과 같습니다.

  • 인터넷 서버 오류
  • 서비스 불가

재시도 및 백 오프 알고리즘

오류는 서버, 스위치,로드 밸런서 및 기타 구조 및 시스템과 같은 다양한 소스에서 발생합니다. 일반적인 솔루션은 안정성을 지원하는 간단한 재시 도로 구성됩니다. 모든 SDK에는이 로직이 자동으로 포함되며 애플리케이션 요구에 맞게 재시도 매개 변수를 설정할 수 있습니다.

For example − Java는 재 시도를 중지하기 위해 maxErrorRetry 값을 제공합니다.

Amazon은 흐름을 제어하기 위해 재시도 외에 백 오프 솔루션을 사용할 것을 권장합니다. 이것은 재시도 사이의 대기 기간을 점진적으로 늘리고 결국 상당히 짧은 기간 후에 중지하는 것으로 구성됩니다. 참고 SDK는 자동 재 시도를 수행하지만 지수 백 오프는 수행하지 않습니다.

다음 프로그램은 재시도 백 오프의 예입니다.

public enum Results { 
   SUCCESS,  
   NOT_READY,  
   THROTTLED,  
   SERVER_ERROR 
}
public static void DoAndWaitExample() {  
   try {
      // asynchronous operation. 
      long token = asyncOperation();  
      int retries = 0; 
      boolean retry = false;  
      
      do { 
         long waitTime = Math.min(getWaitTime(retries), MAX_WAIT_INTERVAL);  
         System.out.print(waitTime + "\n");  
         
         // Pause for result 
         Thread.sleep(waitTime);  
         
         // Get result 
         Results result = getAsyncOperationResult(token);  
         
         if (Results.SUCCESS == result) { 
            retry = false; 
         } else if (Results.NOT_READY == result) { 
            retry = true; 
         } else if (Results.THROTTLED == result) { 
            retry = true; 
         } else if (Results.SERVER_ERROR == result) { 
            retry = true; 
         } else { 
            
            // stop on other error 
            retry = false; 
         }  
      } while (retry && (retries++ < MAX_RETRIES)); 
   }
   catch (Exception ex) { 
   } 
}
public static long getWaitTime(int retryCount) {  
   long waitTime = ((long) Math.pow(3, retryCount) * 100L);  
   return waitTime; 
}