DynamoDB - obsługa błędów

Po nieudanym przetworzeniu żądania, DynamoDB zgłasza błąd. Każdy błąd składa się z następujących składników: kod stanu HTTP, nazwa wyjątku i komunikat. Zarządzanie błędami opiera się na Twoim SDK, który propaguje błędy, lub na Twoim własnym kodzie.

Kody i komunikaty

Wyjątki dotyczą różnych kodów stanu nagłówków HTTP. 4xx i 5xx przechowują błędy związane z problemami z żądaniami i AWS.

Oto kilka wyjątków w kategorii HTTP 4xx -

  • AccessDeniedException - Klient nie podpisał poprawnie żądania.

  • ConditionalCheckFailedException - stan uznany za fałszywy.

  • IncompleteSignatureException - Żądanie zawierało niepełny podpis.

Wyjątki w kategorii HTTP 5xx są następujące -

  • Wewnętrzny błąd serwera
  • serwis niedostępny

Algorytmy ponownych prób i wycofywania

Błędy pochodzą z różnych źródeł, takich jak serwery, przełączniki, moduły równoważenia obciążenia i inne elementy struktur i systemów. Typowe rozwiązania obejmują proste ponawianie, co zapewnia niezawodność. Wszystkie zestawy SDK zawierają tę logikę automatycznie i można ustawić parametry ponawiania w celu dostosowania do potrzeb aplikacji.

For example - Java oferuje wartość maxErrorRetry, aby zatrzymać ponowne próby.

Amazon zaleca używanie rozwiązania wycofywania oprócz ponownych prób w celu kontrolowania przepływu. Obejmuje to stopniowo zwiększające się okresy oczekiwania między ponownymi próbami i ostatecznie zatrzymujące się po dość krótkim okresie. Uwaga: zestawy SDK wykonują automatyczne ponowienia, ale nie powodują wykładniczego wycofywania.

Poniższy program jest przykładem wycofywania ponownej próby -

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