2019-02-26 05:50:07 -08:00
# Buffering
How to Read the Request before Forwarding It
{: .subtitle }
![Buffering ](../assets/img/middleware/buffering.png )
2021-02-11 14:34:04 +01:00
The Buffering middleware limits the size of requests that can be forwarded to services.
2019-02-26 05:50:07 -08:00
2021-02-11 14:34:04 +01:00
With Buffering, Traefik reads the entire request into memory (possibly buffering large requests into disk), and rejects requests that are over a specified size limit.
2019-02-26 05:50:07 -08:00
2021-02-11 14:34:04 +01:00
This can help services avoid large amounts of data (`multipart/form-data` for example), and can minimize the time spent sending data to a service.
2019-02-26 05:50:07 -08:00
## Configuration Examples
2019-03-29 12:34:05 +01:00
```yaml tab="Docker"
2021-02-11 14:34:04 +01:00
# Sets the maximum request body to 2MB
2019-03-29 12:34:05 +01:00
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000"
2019-04-03 14:32:04 +02:00
```
```yaml tab="Kubernetes"
2021-02-11 14:34:04 +01:00
# Sets the maximum request body to 2MB
2019-04-03 14:32:04 +02:00
apiVersion: traefik.containo.us/v1alpha1
kind: Middleware
metadata:
name: limit
spec:
buffering:
2019-09-23 14:32:04 +02:00
maxRequestBodyBytes: 2000000
2019-03-29 12:34:05 +01:00
```
2019-10-15 18:34:08 +03:00
```yaml tab="Consul Catalog"
2021-02-11 14:34:04 +01:00
# Sets the maximum request body to 2MB
2019-10-15 18:34:08 +03:00
- "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000"
```
2019-04-15 18:22:07 +02:00
```json tab="Marathon"
"labels": {
2019-09-23 14:32:04 +02:00
"traefik.http.middlewares.limit.buffering.maxRequestBodyBytes": "2000000"
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
# Sets the maximum request body to 2MB
2019-04-08 17:14:08 +02:00
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000"
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
# Sets the maximum request body to 2MB
2019-03-29 12:34:05 +01:00
[http.middlewares]
2019-04-03 14:32:04 +02:00
[http.middlewares.limit.buffering]
2019-09-23 14:32:04 +02:00
maxRequestBodyBytes = 2000000
2019-03-29 12:34:05 +01:00
```
2019-02-26 05:50:07 -08:00
2019-07-22 09:58:04 +02:00
```yaml tab="File (YAML)"
2021-02-11 14:34:04 +01:00
# Sets the maximum request body to 2MB
2019-07-22 09:58:04 +02:00
http:
middlewares:
limit:
buffering:
2019-09-23 14:32:04 +02:00
maxRequestBodyBytes: 2000000
2019-07-22 09:58:04 +02:00
```
2019-02-26 05:50:07 -08:00
## Configuration Options
2019-04-03 14:32:04 +02:00
### `maxRequestBodyBytes`
2019-02-26 05:50:07 -08:00
2021-02-11 14:34:04 +01:00
The `maxRequestBodyBytes` option configures the maximum allowed body size for the request (in bytes).
2019-02-26 05:50:07 -08:00
2021-02-11 14:34:04 +01:00
If the request exceeds the allowed size, it is not forwarded to the service, and the client gets a `413 (Request Entity Too Large)` response.
2019-09-23 14:32:04 +02:00
```yaml tab="Docker"
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000"
2019-09-23 14:32:04 +02:00
```
```yaml tab="Kubernetes"
apiVersion: traefik.containo.us/v1alpha1
kind: Middleware
metadata:
name: limit
spec:
buffering:
maxRequestBodyBytes: 2000000
```
2019-10-15 18:34:08 +03:00
```yaml tab="Consul Catalog"
- "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000"
```
2019-09-23 14:32:04 +02:00
```json tab="Marathon"
"labels": {
"traefik.http.middlewares.limit.buffering.maxRequestBodyBytes": "2000000"
}
```
```yaml tab="Rancher"
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000"
2019-09-23 14:32:04 +02:00
```
```toml tab="File (TOML)"
[http.middlewares]
[http.middlewares.limit.buffering]
maxRequestBodyBytes = 2000000
```
```yaml tab="File (YAML)"
http:
middlewares:
limit:
buffering:
maxRequestBodyBytes: 2000000
```
2019-02-26 05:50:07 -08:00
2019-04-03 14:32:04 +02:00
### `memRequestBodyBytes`
2019-02-26 05:50:07 -08:00
2021-02-11 14:34:04 +01:00
You can configure a threshold (in bytes) from which the request will be buffered on disk instead of in memory with the `memRequestBodyBytes` option.
2019-09-23 14:32:04 +02:00
```yaml tab="Docker"
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.memRequestBodyBytes=2000000"
2019-09-23 14:32:04 +02:00
```
```yaml tab="Kubernetes"
apiVersion: traefik.containo.us/v1alpha1
kind: Middleware
metadata:
name: limit
spec:
buffering:
memRequestBodyBytes: 2000000
```
2019-10-15 18:34:08 +03:00
```yaml tab="Consul Catalog"
- "traefik.http.middlewares.limit.buffering.memRequestBodyBytes=2000000"
```
2019-09-23 14:32:04 +02:00
```json tab="Marathon"
"labels": {
"traefik.http.middlewares.limit.buffering.memRequestBodyBytes": "2000000"
}
```
```yaml tab="Rancher"
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.memRequestBodyBytes=2000000"
2019-09-23 14:32:04 +02:00
```
```toml tab="File (TOML)"
[http.middlewares]
[http.middlewares.limit.buffering]
memRequestBodyBytes = 2000000
```
```yaml tab="File (YAML)"
http:
middlewares:
limit:
buffering:
memRequestBodyBytes: 2000000
```
2019-02-26 05:50:07 -08:00
2019-04-03 14:32:04 +02:00
### `maxResponseBodyBytes`
2019-02-26 05:50:07 -08:00
2021-02-11 14:34:04 +01:00
The `maxResponseBodyBytes` option configures the maximum allowed response size from the service (in bytes).
2019-02-26 05:50:07 -08:00
If the response exceeds the allowed size, it is not forwarded to the client. The client gets a `413 (Request Entity Too Large) response` instead.
2019-09-23 14:32:04 +02:00
```yaml tab="Docker"
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.maxResponseBodyBytes=2000000"
2019-09-23 14:32:04 +02:00
```
```yaml tab="Kubernetes"
apiVersion: traefik.containo.us/v1alpha1
kind: Middleware
metadata:
name: limit
spec:
buffering:
maxResponseBodyBytes: 2000000
```
2019-10-15 18:34:08 +03:00
```yaml tab="Consul Catalog"
- "traefik.http.middlewares.limit.buffering.maxResponseBodyBytes=2000000"
```
2019-09-23 14:32:04 +02:00
```json tab="Marathon"
"labels": {
"traefik.http.middlewares.limit.buffering.maxResponseBodyBytes": "2000000"
}
```
```yaml tab="Rancher"
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.maxResponseBodyBytes=2000000"
2019-09-23 14:32:04 +02:00
```
```toml tab="File (TOML)"
[http.middlewares]
[http.middlewares.limit.buffering]
maxResponseBodyBytes = 2000000
```
```yaml tab="File (YAML)"
http:
middlewares:
limit:
buffering:
maxResponseBodyBytes: 2000000
```
2019-04-03 14:32:04 +02:00
### `memResponseBodyBytes`
2019-02-26 05:50:07 -08:00
2021-02-11 14:34:04 +01:00
You can configure a threshold (in bytes) from which the response will be buffered on disk instead of in memory with the `memResponseBodyBytes` option.
2019-09-23 14:32:04 +02:00
```yaml tab="Docker"
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.memResponseBodyBytes=2000000"
2019-09-23 14:32:04 +02:00
```
```yaml tab="Kubernetes"
apiVersion: traefik.containo.us/v1alpha1
kind: Middleware
metadata:
name: limit
spec:
buffering:
memResponseBodyBytes: 2000000
```
2019-10-15 18:34:08 +03:00
```yaml tab="Consul Catalog"
- "traefik.http.middlewares.limit.buffering.memResponseBodyBytes=2000000"
```
2019-09-23 14:32:04 +02:00
```json tab="Marathon"
"labels": {
"traefik.http.middlewares.limit.buffering.memResponseBodyBytes": "2000000"
}
```
```yaml tab="Rancher"
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.memResponseBodyBytes=2000000"
2019-09-23 14:32:04 +02:00
```
```toml tab="File (TOML)"
[http.middlewares]
[http.middlewares.limit.buffering]
memResponseBodyBytes = 2000000
```
```yaml tab="File (YAML)"
http:
middlewares:
limit:
buffering:
memResponseBodyBytes: 2000000
```
2019-02-26 05:50:07 -08:00
2019-04-03 14:32:04 +02:00
### `retryExpression`
2019-02-26 05:50:07 -08:00
2021-02-11 14:34:04 +01:00
You can have the Buffering middleware replay the request using `retryExpression` .
2019-02-26 05:50:07 -08:00
2021-02-11 14:34:04 +01:00
??? example "Retries once in the case of a network error"
2019-09-23 14:32:04 +02:00
```yaml tab="Docker"
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.retryExpression=IsNetworkError() && Attempts() < 2 "
2019-09-23 14:32:04 +02:00
```
2019-02-26 05:50:07 -08:00
2019-09-23 14:32:04 +02:00
```yaml tab="Kubernetes"
apiVersion: traefik.containo.us/v1alpha1
kind: Middleware
metadata:
name: limit
spec:
buffering:
retryExpression: "IsNetworkError() & & Attempts() < 2 "
```
2019-10-15 18:34:08 +03:00
```yaml tab="Consul Catalog"
- "traefik.http.middlewares.limit.buffering.retryExpression=IsNetworkError() && Attempts() < 2 "
```
2019-09-23 14:32:04 +02:00
```json tab="Marathon"
"labels": {
"traefik.http.middlewares.limit.buffering.retryExpression": "IsNetworkError() & & Attempts() < 2 "
}
```
```yaml tab="Rancher"
labels:
2019-09-23 17:00:06 +02:00
- "traefik.http.middlewares.limit.buffering.retryExpression=IsNetworkError() && Attempts() < 2 "
2019-02-26 05:50:07 -08:00
```
2019-09-23 14:32:04 +02:00
```toml tab="File (TOML)"
[http.middlewares]
[http.middlewares.limit.buffering]
retryExpression = "IsNetworkError() & & Attempts() < 2 "
```
```yaml tab="File (YAML)"
http:
middlewares:
limit:
buffering:
retryExpression: "IsNetworkError() & & Attempts() < 2 "
```
The retry expression is defined as a logical combination of the functions below with the operators AND (`&&` ) and OR (`||` ). At least one function is required:
2019-02-26 05:50:07 -08:00
- `Attempts()` number of attempts (the first one counts)
- `ResponseCode()` response code of the service
2021-02-11 14:34:04 +01:00
- `IsNetworkError()` whether the response code is related to networking error