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; 
}