模块 ngx_stream_ssl_preread_module
嵌入式变量ssl_preread 示例配置 Directives |
模块 (1.11.5) 允许
从 ClientHello 消息中提取信息而不终止 SSL/TLS,
例如,通过 SNI 或 ALPN 中公布的协议请求的服务器名称。
默认情况下,此模块不是构建的,应使用 configuration 参数启用它。ngx_stream_ssl_preread_module
--with-stream_ssl_preread_module
示例配置
根据服务器名称选择上游:
map $ssl_preread_server_name $name { backend.example.com backend; default backend2; } upstream backend { server 192.168.0.1:12345; server 192.168.0.2:12345; } upstream backend2 { server 192.168.0.3:12345; server 192.168.0.4:12345; } server { listen 12346; proxy_pass $name; ssl_preread on; }
根据协议选择上游:
map $ssl_preread_alpn_protocols $proxy { ~\bh2\b 127.0.0.1:8001; ~\bhttp/1.1\b 127.0.0.1:8002; ~\bxmpp-client\b 127.0.0.1:8003; } server { listen 9000; proxy_pass $proxy; ssl_preread on; }
根据 SSL 协议版本选择上游:
map $ssl_preread_protocol $upstream { "" ssh.example.com:22; "TLSv1.2" new.example.com:443; default tls.example.com:443; } # ssh and https on the same port server { listen 192.168.0.1:443; proxy_pass $upstream; ssl_preread on; }
Directives
语法: |
ssl_preread |
---|---|
默认值: |
ssl_preread off; |
上下文: |
stream ,server |
允许从 ClientHello 消息中提取信息 预读阶段。
嵌入变量
$ssl_preread_protocol
- 客户端支持的最高 SSL 协议版本 (1.15.2)
$ssl_preread_server_name
- 通过 SNI 请求的服务器名称
$ssl_preread_alpn_protocols
- 客户端通过 ALPN (1.13.10) 通告的协议列表。 这些值用逗号分隔。