モジュール ngx_stream_ssl_preread_module
| 構成例 ディレクティブ ssl_preread 埋め込み変数 |
ngx_stream_ssl_preread_module モジュール (1.11.5) では、ClientHello メッセージから SSL/TLS を終了することなく情報を抽出できます。たとえば、SNI を介して要求されたサーバ名や、ALPN でアドバタイズされたプロトコルなどです。このモジュールはデフォルトではビルドされません。--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;
}
ディレクティブ
| 構文 |
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) を介してアドバタイズするプロトコルのリスト。値はコンマで区切られます。