This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
docu:csheet:syadm:web:server:haproxy_sni [2020/02/18 16:51] – admin | docu:csheet:syadm:web:server:haproxy_sni [2020/05/10 10:55] (current) – admin | ||
---|---|---|---|
Line 1: | Line 1: | ||
==== Route traffic via the ssl_sni header ==== | ==== Route traffic via the ssl_sni header ==== | ||
+ | Routing **HTTPS traffic** via the **ssl_sni tcp packet header** is a way to balance and create virtual hosts pointing directly to **their tcp port**, so it allows to leave SSL offloading work to the backend, and more useful stuff.\\ | ||
\\ | \\ | ||
+ | As a result, **no http header logic** can be used, as it **operates at TCP level**. | ||
+ | \\ | ||
+ | |||
<code conf> | <code conf> | ||
global | global | ||
Line 9: | Line 13: | ||
defaults | defaults | ||
- | log 127.0.0.1 | + | log / |
- | timeout connect | + | timeout connect |
- | timeout queue | + | timeout client |
- | timeout tarpit | + | timeout server |
- | timeout client | + | |
- | timeout http-request | + | |
- | timeout http-keep-alive 5000 | + | |
- | timeout server | + | |
- | timeout check 7000 | + | |
option tcplog | option tcplog | ||
+ | option logasap | ||
mode tcp | mode tcp | ||
frontend ssl-sni-router | frontend ssl-sni-router | ||
- | bind *:443 v4v6 | + | bind :::443 v4v6 strict-sni alpn h2,http/1.1 |
- | + | ||
tcp-request inspect-delay 5s | tcp-request inspect-delay 5s | ||
+ | |||
+ | # log the ssl sni on the haproxy | ||
+ | tcp-request content capture req.ssl_sni len 24 | ||
+ | log-format " | ||
+ | |||
tcp-request content accept if { req.ssl_hello_type 1 } | tcp-request content accept if { req.ssl_hello_type 1 } | ||
- | | + | |
acl a_somesite req.ssl_sni -i somesite.net | acl a_somesite req.ssl_sni -i somesite.net | ||
use_backend somesite if a_somesite | use_backend somesite if a_somesite | ||
- | default_backend | + | default_backend |
- | backend | + | |
+ | backend | ||
server def1 127.0.0.1: | server def1 127.0.0.1: | ||
+ | |||
backend somesite | backend somesite |