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