Использование обработчика ошибок

Для централизованной обработки ошибок будем использовать “процессор” зарегистрированный через <camelContext errorHandlerRef="…​”>. В частных случаях допустимо использование try …​ catch …​ finally. (https://camel.apache.org/manual/latest/error-handler.html)

Кроме возврата ошибок вызывающей стороне, необходимо дублировать ошибки в JMS очередь с возможностью их просмотра из веб-консоли Артемиса.

Классификация ошибок

Бизнесовые ошибки: отсутствие обязательных полей, превышение длины поля и другие нарушения ожиданий принимающей стороны.

Серверные ошибки: NPE и другие ошибки времени выполнения.

Сервис не доступен: конечная точка не отвечает и не принимает входящие соединения.

При этом ошибки могут быть “восстанавливаемыми” - с возможностью успешной обработки повторного запроса, использующего изменённые данные или другие точки доступа, и “не восстанавливаемыми” - у клиента нет возможности обойти причины ошибки для выбранного сервиса.

Обёртка для ошибок

Ошибки удобно обрабатывать используя дополнительную информацию, которую необходимо передавать вместе с ошибкой:

  • Timestamp: время возникновения ошибки;

  • Error Code: код ошибки для удобства автоматизированной обработки ошибок;

  • Error Text: описание возникающей ошибки, допустимо выводить вместе со стектрейсом;

  • Severity Level: уровень журналирования ошибки;

  • Notification: в случае необходимости уведомлений об ошибке поле должно содержать адрес или список адресов систем/пользователей для оповещения;

  • Retry: информация о возможности повторной отправки сообщения;

  • Uuid и id сообщения.