• Buffering
    • Configuration Examples
    • Configuration Options
      • maxRequestBodyBytes
      • memRequestBodyBytes
      • maxResponseBodyBytes
      • memResponseBodyBytes
      • retryExpression

    Buffering

    How to Read the Request before Forwarding It

    Buffering

    The Buffering middleware gives you control on how you want to read the requests before sending them to services.

    With Buffering, Traefik reads the entire request into memory (possibly buffering large requests into disk), and rejects requests that are over a specified limit.

    This can help services deal with large data (multipart/form-data for example), and can minimize time spent sending data to a service.

    Configuration Examples

    1. # Sets the maximum request body to 2Mb
    2. labels:
    3. - "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=250000"
    1. # Sets the maximum request body to 2Mb
    2. apiVersion: traefik.containo.us/v1alpha1
    3. kind: Middleware
    4. metadata:
    5. name: limit
    6. spec:
    7. buffering:
    8. maxRequestBodyBytes: 250000
    1. "labels": {
    2. "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes": "250000"
    3. }
    1. # Sets the maximum request body to 2Mb
    2. labels:
    3. - "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=250000"
    1. # Sets the maximum request body to 2Mb
    2. [http.middlewares]
    3. [http.middlewares.limit.buffering]
    4. maxRequestBodyBytes = 250000
    1. # Sets the maximum request body to 2Mb
    2. http:
    3. middlewares:
    4. limit:
    5. buffering:
    6. maxRequestBodyBytes: 250000

    Configuration Options

    maxRequestBodyBytes

    With the maxRequestBodyBytes option, you can configure the maximum allowed body size for the request (in Bytes).

    If the request exceeds the allowed size, the request is not forwarded to the service and the client gets a `413 (Request Entity Too Large) response.

    memRequestBodyBytes

    You can configure a thresold (in Bytes) from which the request will be buffered on disk instead of in memory with the memRequestBodyBytes option.

    maxResponseBodyBytes

    With the maxReesponseBodyBytes option, you can configure the maximum allowed response size from the service (in Bytes).

    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.

    memResponseBodyBytes

    You can configure a thresold (in Bytes) from which the response will be buffered on disk instead of in memory with the memResponseBodyBytes option.

    retryExpression

    You can have the Buffering middleware replay the request with the help of the retryExpression option.

    Retries once in case of a network error

    1. retryExpression = "IsNetworkError() && Attempts() < 2"

    Available functions for the retry expression are:

    • Attempts() number of attempts (the first one counts)
    • ResponseCode() response code of the service
    • IsNetworkError() - if the response code is related to networking error