Enhance middleware examples.

This commit is contained in:
Ludovic Fernandez 2019-03-29 12:34:05 +01:00 committed by Traefiker Bot
parent fa2c57f7cb
commit a45f285a5c
15 changed files with 286 additions and 345 deletions

View file

@ -9,34 +9,28 @@ The AddPrefix middleware updates the URL Path of the request before forwarding i
## Configuration Examples ## Configuration Examples
??? example "File -- Prefixing with /foo" ```yaml tab="Docker"
# Prefixing with /foo
labels:
- "traefik.http.middlewares.add-bar.addprefix.prefix=/foo"
```
```toml ```yaml tab="Kubernetes"
[http.middlewares] apiVersion: traefik.containo.us/v1alpha1
[http.middlewares.add-foo.AddPrefix] kind: Middleware
prefix = "/foo" metadata:
``` name: addprefix
spec:
addprefix:
prefix: /bar
```
??? example "Docker -- Prefixing with /bar" ```toml tab="File"
# Prefixing with /foo
```yaml [http.middlewares]
a-container: [http.middlewares.add-foo.AddPrefix]
image: a-container-image prefix = "/foo"
labels: ```
- "traefik.http.middlewares.add-bar.addprefix.prefix=/bar"
```
??? example "Kubernetes -- Prefixing with /bar"
```yaml
apiVersion: traefik.containo.us/v1alpha1
kind: Middleware
metadata:
name: addprefix
spec:
addprefix:
prefix: /bar
```
## Configuration Options ## Configuration Options

View file

@ -9,23 +9,19 @@ The BasicAuth middleware is a quick way to restrict access to your services to k
## Configuration Examples ## Configuration Examples
??? example "File -- Declaring the user list" ```yaml tab="Docker"
# Declaring the user list
labels:
- "traefik.http.middlewares.declared-users-only.basicauth.users=test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/,test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0",
```
```toml ```toml tab="File"
[http.middlewares] # Declaring the user list
[http.middlewares.test-auth.basicauth] [http.middlewares]
users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/", [http.middlewares.test-auth.basicauth]
"test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"] users = ["test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/",
``` "test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0"]
```
??? example "Docker -- Using an external file for the authorized users"
```yml
a-container:
image: a-container-image
labels:
- "traefik.http.middlewares.declared-users-only.basicauth.usersFile=path-to-file.ext",
```
## Configuration Options ## Configuration Options

View file

@ -13,22 +13,18 @@ This can help services deal with large data (multipart/form-data for example), a
## Configuration Examples ## Configuration Examples
??? example "File -- Sets the maximum request body to 2Mb" ```yaml tab="Docker"
# Sets the maximum request body to 2Mb
labels:
- "traefik.http.middlewares.2Mb-memory.buffering.maxRequestBodyBytes=250000",
```
```toml ```toml tab="File"
[http.middlewares] # Sets the maximum request body to 2Mb
[http.middlewares.2Mb-limit.buffering] [http.middlewares]
maxRequestBodyBytes = 250000 [http.middlewares.2Mb-limit.buffering]
``` maxRequestBodyBytes = 250000
```
??? example "Docker -- Buffers 1Mb of the request in memory, then writes to disk"
```yaml
a-container:
image: a-container-image
labels:
- "traefik.http.middlewares.1Mb-memory.buffering.memRequestBodyBytes=125000",
```
## Configuration Options ## Configuration Options

View file

@ -23,23 +23,18 @@ To assess if your system is healthy, the circuit breaker constantly monitors the
## Configuration Examples ## Configuration Examples
??? example "Latency Check -- Using Toml" ```yaml tab="Docker"
# Latency Check
labels:
- "traefik.http.middlewares.latency-check.circuitbreaker.expression=LatencyAtQuantileMS(50.0) > 100"
```
```toml ```toml tab="File"
[http.middlewares] # Latency Check
[http.middlewares.latency-check.circuitbreaker] [http.middlewares]
expression = "LatencyAtQuantileMS(50.0) > 100" [http.middlewares.latency-check.circuitbreaker]
``` expression = "LatencyAtQuantileMS(50.0) > 100"
```
??? example "Latency Check -- Using Docker Labels"
```yaml
# in a docker compose file
container-definition:
image: image-name
labels:
- "traefik.http.middlewares.latency-check.circuitbreaker.expression=LatencyAtQuantileMS(50.0) > 100"
```
## Possible States ## Possible States

View file

@ -9,21 +9,17 @@ The Compress middleware enables the gzip compression.
## Configuration Examples ## Configuration Examples
??? example "File -- enable gzip compression" ```yaml tab="Docker"
# Enable gzip compression
labels:
- "traefik.http.middlewares.test-compress.compress=true",
```
```toml ```toml tab="File"
[http.middlewares] # Enable gzip compression
[http.middlewares.test-compress.Compress] [http.middlewares]
``` [http.middlewares.test-compress.Compress]
```
??? example "Docker -- enable gzip compression"
```yml
a-container:
image: a-container-image
labels:
- "traefik.http.middlewares.test-compress.compress=true",
```
## Notes ## Notes

View file

@ -9,23 +9,17 @@ The DigestAuth middleware is a quick way to restrict access to your services to
## Configuration Examples ## Configuration Examples
??? example "File -- Declaring the user list" ```yaml tab="Docker"
labels:
- "traefik.http.middlewares.declared-users-only.digestauth.usersFile=path-to-file.ext",
```
```toml ```toml tab="File"
[http.middlewares] [http.middlewares]
[http.middlewares.test-auth.digestauth] [http.middlewares.test-auth.digestauth]
users = ["test:traefik:a2688e031edb4be6a3797f3882655c05", users = ["test:traefik:a2688e031edb4be6a3797f3882655c05",
"test2:traefik:518845800f9e2bfb1f1f740ec24f074e"] "test2:traefik:518845800f9e2bfb1f1f740ec24f074e"]
``` ```
??? example "Docker -- Using an external file for the authorized users"
```yml
a-container:
image: a-container-image
labels:
- "traefik.http.middlewares.declared-users-only.digestauth.usersFile=path-to-file.ext",
```
!!! tip !!! tip

View file

@ -12,38 +12,33 @@ The ErrorPage middleware returns a custom page in lieu of the default, according
## Configuration Examples ## Configuration Examples
??? example "File -- Custom Error Page for 5XX" ```yaml tab="Docker"
# Dynamic Custom Error Page for 5XX Status Code
labels:
- "traefik.http.middlewares.test-errorpage.errors.status=500-599",
- "traefik.http.middlewares.test-errorpage.errors.service=serviceError",
- "traefik.http.middlewares.test-errorpage.errors.query=/{status}.html",
```
```toml ```toml tab="File"
[http.routers] # Custom Error Page for 5XX
[http.routers.router1] [http.routers]
Service = "my-service" [http.routers.router1]
Rule = Host(`my-domain`) Service = "my-service"
Rule = Host(`my-domain`)
[http.middlewares] [http.middlewares]
[http.middlewares.5XX-errors.Errors] [http.middlewares.5XX-errors.Errors]
status = ["500-599"] status = ["500-599"]
service = "error-handler-service" service = "error-handler-service"
query = "/error.html" query = "/error.html"
[http.services] [http.services]
# ... definition of error-handler-service and my-service # ... definition of error-handler-service and my-service
``` ```
??? example "Docker -- Dynamic Custom Error Page for 5XX Status Code" !!! note
In this example, the error page URL is based on the status code (`query=/{status}.html)`.
```yaml
a-container:
image: a-container-image
labels:
- "traefik.http.middlewares.test-errorpage.errors.status=500-599",
- "traefik.http.middlewares.test-errorpage.errors.service=serviceError",
- "traefik.http.middlewares.test-errorpage.errors.query=/{status}.html",
```
!!! note
In this example, the error page URL is based on the status code (`query=/{status}.html)`.
## Configuration Options ## Configuration Options

View file

@ -11,38 +11,33 @@ Otherwise, the response from the authentication server is returned.
## Configuration Examples ## Configuration Examples
??? example "File -- Forward authentication to authserver.com" ```toml tab="File"
# Forward authentication to authserver.com
[http.middlewares]
[http.middlewares.test-auth.forwardauth]
address = "https://authserver.com/auth"
trustForwardHeader = true
authResponseHeaders = ["X-Auth-User", "X-Secret"]
```toml [http.middlewares.test-auth.forwardauth.tls]
[http.middlewares] ca = "path/to/local.crt"
[http.middlewares.test-auth.forwardauth] caOptional = true
address = "https://authserver.com/auth" cert = "path/to/foo.cert"
trustForwardHeader = true key = "path/to/foo.key"
authResponseHeaders = ["X-Auth-User", "X-Secret"] ```
[http.middlewares.test-auth.forwardauth.tls] ```yaml tab="Docker"
ca = "path/to/local.crt" # Forward authentication to authserver.com
caOptional = true labels:
cert = "path/to/foo.cert" - "traefik.http.middlewares.test-auth.ForwardAuth.Address=https://authserver.com/auth"
key = "path/to/foo.key" - "traefik.http.middlewares.test-auth.ForwardAuth.AuthResponseHeaders=X-Auth-User, X-Secret"
``` - "traefik.http.middlewares.test-auth.ForwardAuth.TLS.CA=path/to/local.crt"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.CAOptional=true"
??? example "Docker -- Forward authentication to authserver.com" - "traefik.http.middlewares.test-auth.ForwardAuth.TLS.Cert=path/to/foo.cert"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.InsecureSkipVerify=true"
```yml - "traefik.http.middlewares.test-auth.ForwardAuth.TLS.Key=path/to/foo.key"
a-container: - "traefik.http.middlewares.test-auth.ForwardAuth.TrustForwardHeader=true"
image: a-container-image ```
labels:
- "traefik.http.middlewares.test-auth.ForwardAuth.Address=https://authserver.com/auth"
- "traefik.http.middlewares.test-auth.ForwardAuth.AuthResponseHeaders=X-Auth-User, X-Secret"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.CA=path/to/local.crt"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.CAOptional=true"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.Cert=path/to/foo.cert"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.InsecureSkipVerify=true"
- "traefik.http.middlewares.test-auth.ForwardAuth.TLS.Key=path/to/foo.key"
- "traefik.http.middlewares.test-auth.ForwardAuth.TrustForwardHeader=true"
```
## Configuration Options ## Configuration Options

View file

@ -13,26 +13,22 @@ The Headers middleware can manage the requests/responses headers.
Add the `X-Script-Name` header to the proxied request and the `X-Custom-Response-Header` to the response Add the `X-Script-Name` header to the proxied request and the `X-Custom-Response-Header` to the response
??? example "File" ```yaml tab="Docker"
a-container:
image: a-container-image
labels:
- "traefik.http.middlewares.testHeader.Headers.CustomRequestHeaders.X-Script-Name=test",
- "traefik.http.middlewares.testHeader.Headers.CustomResponseHeaders.X-Custom-Response-Header=True",
```
```toml ```toml tab="File"
[http.middlewares] [http.middlewares]
[http.middlewares.testHeader.headers] [http.middlewares.testHeader.headers]
[http.middlewares.testHeader.headers.CustomRequestHeaders] [http.middlewares.testHeader.headers.CustomRequestHeaders]
X-Script-Name = "test" X-Script-Name = "test"
[http.middlewares.testHeader.headers.CustomResponseHeaders] [http.middlewares.testHeader.headers.CustomResponseHeaders]
X-Custom-Response-Header = "True" X-Custom-Response-Header = "True"
``` ```
??? example "Docker"
```yml
a-container:
image: a-container-image
labels:
- "traefik.http.middlewares.testHeader.Headers.CustomRequestHeaders.X-Script-Name=test",
- "traefik.http.middlewares.testHeader.Headers.CustomResponseHeaders.X-Custom-Response-Header=True",
```
### Adding and Removing Headers ### Adding and Removing Headers

View file

@ -9,22 +9,18 @@ IPWhitelist accepts / refuses requests based on the client IP.
## Configuration Examples ## Configuration Examples
??? example "File -- Accepts request from defined IP" ```yaml tab="Docker"
# Accepts request from defined IP
labels:
- "traefik.http.middlewares.Middleware9.IPWhiteList.SourceRange=127.0.0.1/32, 192.168.1.7"
```
```toml ```toml tab="File"
[http.middlewares] # Accepts request from defined IP
[http.middlewares.test-ipwhitelist.ipWhiteList] [http.middlewares]
sourceRange = ["127.0.0.1/32", "192.168.1.7"] [http.middlewares.test-ipwhitelist.ipWhiteList]
``` sourceRange = ["127.0.0.1/32", "192.168.1.7"]
```
??? example "Docker -- Accepts request from defined IP"
```yml
a-container:
image: a-container-image
labels:
- "traefik.http.middlewares.Middleware9.IPWhiteList.SourceRange=127.0.0.1/32, 192.168.1.7"
```
## Configuration Options ## Configuration Options

View file

@ -9,22 +9,18 @@ To proactively prevent services from being overwhelmed with high load, a maximum
## Configuration Examples ## Configuration Examples
??? example "File -- Limiting to 10 simultaneous connections" ```yaml tab="Docker"
# Limiting to 10 simultaneous connections
labels:
- "traefik.http.middlewares.test-maxconn.maxconn.amount=10"
```
```toml ```toml tab="File"
[http.middlewares] # Limiting to 10 simultaneous connections
[http.middlewares.test-maxconn.maxconn] [http.middlewares]
amount = 10 [http.middlewares.test-maxconn.maxconn]
``` amount = 10
```
??? example "Docker -- Limiting to 10 simultaneous connections"
```yml
a-container:
image: a-container-image
labels:
- "traefik.http.middlewares.test-maxconn.maxconn.amount=10"
```
## Configuration Options ## Configuration Options

View file

@ -13,79 +13,75 @@ Pieces of middleware can be combined in chains to fit every scenario.
## Configuration Example ## Configuration Example
??? example "As Toml Configuration File" ```yaml tab="Docker"
# As a Docker Label
whoami:
image: containous/whoami # A container that exposes an API to show its IP address
labels:
- "traefik.http.middlewares.foo-add-prefix.addprefix.prefix=/foo",
```
```toml ```yaml tab="Kubernetes"
[providers] # As a Kubernetes Traefik IngressRoute
[providers.file] apiVersion: apiextensions.k8s.io/v1beta1
kind: CustomResourceDefinition
[http.routers] metadata:
[http.routers.router1] name: middlewares.traefik.containo.us
Service = "myService" spec:
Middlewares = ["foo-add-prefix"] group: traefik.containo.us
Rule = "Host(`example.com`)" version: v1alpha1
names:
[http.middlewares]
[http.middlewares.foo-add-prefix.AddPrefix]
prefix = "/foo"
[http.services]
[http.services.service1]
[http.services.service1.LoadBalancer]
[[http.services.service1.LoadBalancer.Servers]]
URL = "http://127.0.0.1:80"
Weight = 1
```
??? example "As a Docker Label"
```yaml
# A container that exposes a simple API
whoami:
image: containous/whoami # A container that exposes an API to show its IP address
labels:
- "traefik.http.middlewares.foo-add-prefix.addprefix.prefix=/foo",
```
??? example "As a Kubernetes Traefik IngressRoute"
```yaml
apiVersion: apiextensions.k8s.io/v1beta1
kind: CustomResourceDefinition
metadata:
name: middlewares.traefik.containo.us
spec:
group: traefik.containo.us
version: v1alpha1
names:
kind: Middleware
plural: middlewares
singular: middleware
scope: Namespaced
---
apiVersion: traefik.containo.us/v1alpha1
kind: Middleware kind: Middleware
metadata: plural: middlewares
name: stripprefix singular: middleware
spec: scope: Namespaced
stripprefix:
prefixes:
- /stripit
--- ---
apiVersion: traefik.containo.us/v1alpha1 apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute kind: Middleware
metadata: metadata:
name: ingressroute.crd name: stripprefix
spec: spec:
stripprefix:
prefixes:
- /stripit
---
apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute
metadata:
name: ingressroute.crd
spec:
# more fields...
routes:
# more fields... # more fields...
routes: middleware:
# more fields... - name: stripprefix
middleware: ```
- name: stripprefix
``` ```toml tab="File"
# As Toml Configuration File
[providers]
[providers.file]
[http.routers]
[http.routers.router1]
Service = "myService"
Middlewares = ["foo-add-prefix"]
Rule = "Host(`example.com`)"
[http.middlewares]
[http.middlewares.foo-add-prefix.AddPrefix]
prefix = "/foo"
[http.services]
[http.services.service1]
[http.services.service1.LoadBalancer]
[[http.services.service1.LoadBalancer.Servers]]
URL = "http://127.0.0.1:80"
Weight = 1
```
## Advanced Configuration ## Advanced Configuration

View file

@ -9,26 +9,47 @@ PassTLSClientCert adds in header the selected data from the passed client tls ce
## Configuration Examples ## Configuration Examples
??? example "File -- Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header" Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header.
```toml ```yaml tab="Docker"
[http.middlewares] # Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header.
[http.middlewares.test-passtlsclientcert.passtlsclientcert] labels:
pem = true - "traefik.http.middlewares.Middleware11.passtlsclientcert.pem=true"
```
```toml tab="File"
# Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header.
[http.middlewares]
[http.middlewares.test-passtlsclientcert.passtlsclientcert]
pem = true
```
??? example "Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header"
```yaml tab="Docker"
# Pass all the available info in the `X-Forwarded-Tls-Client-Cert-Info` header
labels:
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.notafter=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.notbefore=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.sans=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.commonname=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.country=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.domaincomponent=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.locality=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.organization=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.province=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.serialnumber=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.commonname=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.country=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.domaincomponent=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.locality=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.organization=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.province=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.serialnumber=true"
``` ```
??? example "Docker -- Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header" ```toml tab="File"
# Pass all the available info in the `X-Forwarded-Tls-Client-Cert-Info` header
```yml
a-container:
image: a-container-image
labels:
- "traefik.http.middlewares.Middleware11.passtlsclientcert.pem=true"
```
??? example "File -- Pass all the available info in the `X-Forwarded-Tls-Client-Cert-Info` header"
```toml
[http.middlewares] [http.middlewares]
[http.middlewares.test-passtlsclientcert.passtlsclientcert] [http.middlewares.test-passtlsclientcert.passtlsclientcert]
[http.middlewares.test-passtlsclientcert.passtlsclientcert.info] [http.middlewares.test-passtlsclientcert.passtlsclientcert.info]
@ -53,31 +74,6 @@ PassTLSClientCert adds in header the selected data from the passed client tls ce
domainComponent = true domainComponent = true
``` ```
??? example "Docker -- Pass all the available info in the `X-Forwarded-Tls-Client-Cert-Info` header"
```yml
a-container:
image: a-container-image
labels:
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.notafter=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.notbefore=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.sans=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.commonname=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.country=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.domaincomponent=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.locality=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.organization=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.province=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.serialnumber=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.commonname=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.country=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.domaincomponent=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.locality=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.organization=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.province=true"
- "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.serialnumber=true"
```
## Configuration Options ## Configuration Options
### General ### General

View file

@ -13,31 +13,31 @@ The RateLimit middleware ensures that services will receive a _fair_ number of r
```toml ```toml
[http.middlewares] [http.middlewares]
[http.middlewares.fair-ratelimit.ratelimit] [http.middlewares.fair-ratelimit.ratelimit]
extractorfunc = "client.ip" extractorfunc = "client.ip"
[http.middlewares.fair-ratelimit.ratelimit.rateset1] [http.middlewares.fair-ratelimit.ratelimit.rateset1]
period = "10s" period = "10s"
average = 100 average = 100
burst = 200 burst = 200
``` ```
??? example "Combine multiple limits" ??? example "Combine multiple limits"
```toml ```toml
[http.middlewares] [http.middlewares]
[http.middlewares.fair-ratelimit.ratelimit] [http.middlewares.fair-ratelimit.ratelimit]
extractorfunc = "client.ip" extractorfunc = "client.ip"
[http.middlewares.fair-ratelimit.ratelimit.rateset1] [http.middlewares.fair-ratelimit.ratelimit.rateset1]
period = "10s" period = "10s"
average = 100 average = 100
burst = 200 burst = 200
[http.middlewares.fair-ratelimit.ratelimit.rateset2] [http.middlewares.fair-ratelimit.ratelimit.rateset2]
period = "3s" period = "3s"
average = 5 average = 5
burst = 10 burst = 10
``` ```
Here, an average of 5 requests every 3 seconds is allowed and an average of 100 requests every 10 seconds. These can "burst" up to 10 and 200 in each period, respectively. Here, an average of 5 requests every 3 seconds is allowed and an average of 100 requests every 10 seconds. These can "burst" up to 10 and 200 in each period, respectively.

View file

@ -1,5 +1,5 @@
mkdocs==1.0.4 mkdocs==1.0.4
pymdown-extensions==6.0 pymdown-extensions==6.0
mkdocs-bootswatch==1.0 mkdocs-bootswatch==1.0
mkdocs-material==3.3.0 mkdocs-material==4.0.2
markdown-include==0.5.1 markdown-include==0.5.1