モジュール 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) を介してアドバタイズするプロトコルのリスト。値はコンマで区切られます。