DocsEmissary-ingress
3.5
Automatic retries
Automatic retries
Sometimes requests fail. When these requests fail for transient issues, Emissary-ingress can automatically retry the request.
Retry policy can be set for all Emissary-ingress mappings in the ambassador Module, or set per Mapping. Generally speaking, you should set retry_policy on a per mapping basis. Global retries can easily result in unexpected cascade failures.
Note that when setting
retry_policy, adjustingmax_retriesin the circuit breaker configuration should also be considered in order to account for all desired retries.
Configuring retries
The retry_policy attribute configures automatic retries. The following fields are supported:
retry_on
(Required) Specifies the condition under which Emissary-ingress retries a failed request.
| Value | Description | 
|---|---|
| 5xx | Retries if the upstream service responds with any 5xx code or does not respond at all | 
| gateway-error | Similar to a 5xxbut only applies to a 502, 503, or 504 response | 
| connect-failure | Retries on a connection failure to the upstream service (included in 5xx) | 
| retriable-4xx | Retries on a retriable 4xx response (currently only 409) | 
| refused-stream | Retires if the upstream service sends a REFUSED_STREAM error (included in 5xx) | 
| retriable-status-codes | Retries based on status codes set in the x-envoy-retriable-status-codesheader. If that header isn't set, Emissary-ingress will not retry the request. | 
For more details on each of these values, see the Envoy documentation.
num_retries
(Default: 1) Specifies the number of retries to execute for a failed request.
per_try_timeout
(Default: global request timeout) Specify the timeout for each retry. Must be in seconds or nanoseconds, e.g., 1s, 1500ns.
Examples
A per mapping retry policy:
A global retry policy (not recommended):
ON THIS PAGE