Skip to main content

Error Handling

Restate handles retries for failed invocations. By default, Restate does infinite retries with an exponential backoff strategy.

For failures for which you do not want retries, but instead want the invocation to end and the error message to be propagated back to the caller, you can throw a terminal error.

You can throw a terminal exception with an HTTP status code and a message anywhere in your handler, as follows:


throw new TerminalException(500, "Something went wrong");

You can catch terminal exceptions. For example, you can catch the terminal exception that comes out of a call to another service, and build your control flow around it.