From ba7e9ed788fdfd77c8cfd6665bbe2264fc43c6d2 Mon Sep 17 00:00:00 2001 From: Roman Tomjak <6570684+romantomjak@users.noreply.github.com> Date: Tue, 14 Jun 2022 11:24:08 +0100 Subject: [PATCH] Add a note on how to handle server first protocols --- docs/content/routing/routers/index.md | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/docs/content/routing/routers/index.md b/docs/content/routing/routers/index.md index d22f034df..fe123bd37 100644 --- a/docs/content/routing/routers/index.md +++ b/docs/content/routing/routers/index.md @@ -673,6 +673,21 @@ If no matching route is found for the TCP routers, then the HTTP routers will ta If not specified, TCP routers will accept requests from all defined entry points. If you want to limit the router scope to a set of entry points, set the entry points option. +??? info "How to handle Server First protocols?" + + To correctly handle a request, Traefik needs to wait for the first + few bytes to arrive before it can decide what to do with it. + + For protocols where the server is expected to send first, such + as SMTP, if no specific setup is in place, we could end up in + a situation where both sides are waiting for data and the + connection appears to have hanged. + + The only way that Traefik can deal with such a case, is to make + sure that on the concerned entry point, there is no TLS router + whatsoever (neither TCP nor HTTP), and there is at least one + non-TLS TCP router that leads to the server in question. + ??? example "Listens to Every Entry Point" **Dynamic Configuration**