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