2019-04-08 17:14:08 +02:00
# Retry
2019-02-26 05:50:07 -08:00
Retrying until it Succeeds
{: .subtitle }
2019-09-10 14:40:05 +02:00
<!--
TODO: add schema
-->
2019-02-26 05:50:07 -08:00
2021-02-11 14:34:04 +01:00
The Retry middleware reissues requests a given number of times to a backend server if that server does not reply.
As soon as the server answers, the middleware stops retrying, regardless of the response status.
The Retry middleware has an optional configuration to enable an exponential backoff.
2019-02-26 05:50:07 -08:00
2019-04-08 17:14:08 +02:00
## Configuration Examples
2019-02-26 05:50:07 -08:00
2019-04-08 17:14:08 +02:00
```yaml tab="Docker"
2021-02-11 14:34:04 +01:00
# Retry 4 times with exponential backoff
2019-04-08 17:14:08 +02:00
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.test-retry.retry.attempts=4"
2020-11-05 10:14:04 -05:00
- "traefik.http.middlewares.test-retry.retry.initialinterval=100ms"
2019-02-26 05:50:07 -08:00
```
2019-04-08 17:14:08 +02:00
```yaml tab="Kubernetes"
2021-02-11 14:34:04 +01:00
# Retry 4 times with exponential backoff
2019-04-08 17:14:08 +02:00
apiVersion: traefik.containo.us/v1alpha1
kind: Middleware
metadata:
name: test-retry
spec:
retry:
attempts: 4
2020-11-05 10:14:04 -05:00
initialInterval: 100ms
2019-04-08 17:14:08 +02:00
```
2019-10-15 18:34:08 +03:00
```yaml tab="Consul Catalog"
2021-02-11 14:34:04 +01:00
# Retry 4 times with exponential backoff
2019-10-15 18:34:08 +03:00
- "traefik.http.middlewares.test-retry.retry.attempts=4"
2020-11-05 10:14:04 -05:00
- "traefik.http.middlewares.test-retry.retry.initialinterval=100ms"
2019-10-15 18:34:08 +03:00
```
2019-04-15 18:22:07 +02:00
```json tab="Marathon"
"labels": {
2020-11-05 10:14:04 -05:00
"traefik.http.middlewares.test-retry.retry.attempts": "4",
"traefik.http.middlewares.test-retry.retry.initialinterval": "100ms",
2019-04-15 18:22:07 +02:00
}
```
2019-04-08 17:14:08 +02:00
```yaml tab="Rancher"
2021-02-11 14:34:04 +01:00
# Retry 4 times with exponential backoff
2019-04-08 17:14:08 +02:00
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.test-retry.retry.attempts=4"
2020-11-05 10:14:04 -05:00
- "traefik.http.middlewares.test-retry.retry.initialinterval=100ms"
2019-04-08 17:14:08 +02:00
```
2019-07-22 09:58:04 +02:00
```toml tab="File (TOML)"
2021-02-11 14:34:04 +01:00
# Retry 4 times with exponential backoff
2019-04-08 17:14:08 +02:00
[http.middlewares]
2019-07-01 11:30:05 +02:00
[http.middlewares.test-retry.retry]
2020-11-05 10:14:04 -05:00
attempts = 4
initialInterval = "100ms"
2019-04-08 17:14:08 +02:00
```
2019-07-22 09:58:04 +02:00
```yaml tab="File (YAML)"
2021-02-11 14:34:04 +01:00
# Retry 4 times with exponential backoff
2019-07-22 09:58:04 +02:00
http:
middlewares:
test-retry:
retry:
2020-11-05 10:14:04 -05:00
attempts: 4
initialInterval: 100ms
2019-07-22 09:58:04 +02:00
```
2019-04-08 17:14:08 +02:00
## Configuration Options
2020-11-05 10:14:04 -05:00
### `attempts`
2019-04-08 17:14:08 +02:00
_mandatory_
2019-09-23 17:00:06 +02:00
The `attempts` option defines how many times the request should be retried.
2020-11-05 10:14:04 -05:00
### `initialInterval`
2021-02-11 14:34:04 +01:00
The `initialInterval` option defines the first wait time in the exponential backoff series. The maximum interval is
calculated as twice the `initialInterval` . If unspecified, requests will be retried immediately.
The value of initialInterval should be provided in seconds or as a valid duration format, see [time.ParseDuration ](https://golang.org/pkg/time/#ParseDuration ).