github.com/krum110487/go-htaccess@v0.0.0-20240316004156-60641c8e7598/tests/data/apache_2_2_34/manual/mod/mod_proxy_balancer.html.ja.utf8 (about) 1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 3 <html xmlns="http://www.w3.org/1999/xhtml" lang="ja" xml:lang="ja"><head> 4 <meta content="text/html; charset=UTF-8" http-equiv="Content-Type" /> 5 <!-- 6 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX 7 This file is generated from xml source: DO NOT EDIT 8 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX 9 --> 10 <title>mod_proxy_balancer - Apache HTTP サーバ バージョン 2.2</title> 11 <link href="../style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" /> 12 <link href="../style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" /> 13 <link href="../style/css/manual-print.css" rel="stylesheet" media="print" type="text/css" /><link rel="stylesheet" type="text/css" href="../style/css/prettify.css" /> 14 <script src="../style/scripts/prettify.min.js" type="text/javascript"> 15 </script> 16 17 <link href="../images/favicon.ico" rel="shortcut icon" /><link href="http://httpd.apache.org/docs/current/mod/mod_proxy_balancer.html" rel="canonical" /></head> 18 <body> 19 <div id="page-header"> 20 <p class="menu"><a href="../mod/">モジュール</a> | <a href="../mod/directives.html">ディレクティブ</a> | <a href="http://wiki.apache.org/httpd/FAQ">FAQ</a> | <a href="../glossary.html">用語</a> | <a href="../sitemap.html">サイトマップ</a></p> 21 <p class="apache">Apache HTTP サーバ バージョン 2.2</p> 22 <img alt="" src="../images/feather.gif" /></div> 23 <div class="up"><a href="./"><img title="<-" alt="<-" src="../images/left.gif" /></a></div> 24 <div id="path"> 25 <a href="http://www.apache.org/">Apache</a> > <a href="http://httpd.apache.org/">HTTP サーバ</a> > <a href="http://httpd.apache.org/docs/">ドキュメンテーション</a> > <a href="../">バージョン 2.2</a> > <a href="./">モジュール</a></div> 26 <div id="page-content"> 27 <div class="retired"><h4>Please note</h4> 28 <p> This document refers to a legacy release (<strong>2.2</strong>) of Apache httpd. The active release (<strong>2.4</strong>) is documented <a href="http://httpd.apache.org/docs/current">here</a>. If you have not already upgraded, please follow <a href="http://httpd.apache.org/docs/current/upgrading.html">this link</a> for more information.</p> 29 <p>You may follow <a href="http://httpd.apache.org/docs/current/mod/mod_proxy_balancer.html">this link</a> to go to the current version of this document.</p></div><div id="preamble"><h1>Apache モジュール mod_proxy_balancer</h1> 30 <div class="toplang"> 31 <p><span>翻訳済み言語: </span><a href="../en/mod/mod_proxy_balancer.html" hreflang="en" rel="alternate" title="English"> en </a> | 32 <a href="../ja/mod/mod_proxy_balancer.html" title="Japanese"> ja </a></p> 33 </div> 34 <div class="outofdate">この日本語訳はすでに古くなっている 35 可能性があります。 36 最近更新された内容を見るには英語版をご覧下さい。 37 </div> 38 <table class="module"><tr><th><a href="module-dict.html#Description">説明:</a></th><td>負荷分散のための <code class="module"><a href="../mod/mod_proxy.html">mod_proxy</a></code> 拡張</td></tr> 39 <tr><th><a href="module-dict.html#Status">ステータス:</a></th><td>Extension</td></tr> 40 <tr><th><a href="module-dict.html#ModuleIdentifier">モジュール識別子:</a></th><td>proxy_balancer_module</td></tr> 41 <tr><th><a href="module-dict.html#SourceFile">ソースファイル:</a></th><td>mod_proxy_balancer.c</td></tr> 42 <tr><th><a href="module-dict.html#Compatibility">互換性:</a></th><td>Apache 2.1 以降で使用可能</td></tr></table> 43 <h3>概要</h3> 44 45 <p>本モジュールには <code class="module"><a href="../mod/mod_proxy.html">mod_proxy</a></code> が<em>必要です</em>。 46 本モジュールは <code>HTTP</code> と <code>FTP</code> と <code>AJP13</code> 47 プロトコルのロードバランス機能を持っています。</p> 48 49 <p>ですから、 ロードバランスを有効にする場合 <code class="module"><a href="../mod/mod_proxy.html">mod_proxy</a></code> 50 と <code class="module"><a href="../mod/mod_proxy_balancer.html">mod_proxy_balancer</a></code> がサーバに組み込まれて 51 いなければいけません。</p> 52 53 <div class="warning"><h3>警告</h3> 54 <p><a href="mod_proxy.html#access"> 55 安全なサーバにする</a>までプロキシ機能は有効にしないでください。 56 オープンプロキシサーバはあなた自身のネットワークにとっても、 57 インターネット全体にとっても危険です。</p> 58 </div> 59 </div> 60 <div id="quickview"><h3>トピック</h3> 61 <ul id="topics"> 62 <li><img alt="" src="../images/down.gif" /> <a href="#scheduler">ロードバランサのスケジューラのアルゴリズム</a></li> 63 <li><img alt="" src="../images/down.gif" /> <a href="#stickyness">ロードバランサのスティッキネス</a></li> 64 <li><img alt="" src="../images/down.gif" /> <a href="#example">ロードバランサの設定例</a></li> 65 <li><img alt="" src="../images/down.gif" /> <a href="#requests">Request Counting アルゴリズム</a></li> 66 <li><img alt="" src="../images/down.gif" /> <a href="#traffic">Weighted Traffic Counting アルゴリズム</a></li> 67 <li><img alt="" src="../images/down.gif" /> <a href="#busyness">Pending Request Counting アルゴリズム</a></li> 68 <li><img alt="" src="../images/down.gif" /> <a href="#environment">エクスポートされる環境変数</a></li> 69 <li><img alt="" src="../images/down.gif" /> <a href="#balancer_manager">バランサマネージャのサポートを有効にする</a></li> 70 <li><img alt="" src="../images/down.gif" /> <a href="#stickyness_implementation">ロードバランサのスティッキネスの詳細</a></li> 71 <li><img alt="" src="../images/down.gif" /> <a href="#stickyness_troubleshooting">ロードバランサのスティッキネスのトラブルシューティング</a></li> 72 </ul><h3 class="directives">ディレクティブ</h3> 73 <p>このモジュールにディレクティブはありません。</p> 74 <h3>参照</h3> 75 <ul class="seealso"> 76 <li><code class="module"><a href="../mod/mod_proxy.html">mod_proxy</a></code></li> 77 </ul><ul class="seealso"><li><a href="#comments_section">コメント</a></li></ul></div> 78 <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> 79 <div class="section"> 80 <h2><a name="scheduler" id="scheduler">ロードバランサのスケジューラのアルゴリズム</a></h2> 81 82 <p>現時点では 3 種類のロードバランサスケジューラアルゴリズムから選べます。 83 リクエスト回数によるもの <span class="transnote">(<em>訳注:</em> Request Counting)</span> 84 、トラフィック量によるもの <span class="transnote">(<em>訳注:</em> Weighted Traffic Counting)</span> 85 と、処理中リクエスト数によるもの <span class="transnote">(<em>訳注:</em> Pending Request Counting)</span> 86 とがあります。バランサの設定 <code>lbmethod</code> 値で、どれを使うか指定します。 87 詳細は <code class="directive"><a href="../mod/mod_proxy.html#proxypass">ProxyPass</a></code> ディレクティブを 88 参照してください。</p> 89 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> 90 <div class="section"> 91 <h2><a name="stickyness" id="stickyness">ロードバランサのスティッキネス</a></h2> 92 93 <p>バランサはスティッキネスをサポートします。リクエストがあるバックエンドに 94 プロキシされた時、続く同じユーザからのリクエストは、すべてその同じバックエンドに 95 プロキシされるべきです。多くのロードバランサはこの機能をクライアントの 96 IP アドレスとバックエンドの対応表を持つことで実現します。 97 この方法はクライアントにもバックエンドにも透過に動作しますが、 98 次に挙げるいくつかの問題があります。 99 もしクライアント自身がプロキシの背後にいる場合、負荷分散が不均一になります。 100 もし動的な IP アドレスを持つクライアントのアドレスがセッション中に変わると 101 スティッキネスは期待どおりに動作しません。 102 もし対応表があふれると、スティッキネスが失われます。</p> 103 <p><code class="module"><a href="../mod/mod_proxy_balancer.html">mod_proxy_balancer</a></code> はスティッキネスを 104 2 種類の別手法をもとに実装しています。クッキーと URL エンコーディングのふたつです。 105 クッキーはバックエンドもしくは Apache Web サーバ自身により提供されます。 106 URL エンコーディングは通常バックエンドにより行われます。</p> 107 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> 108 <div class="section"> 109 <h2><a name="example" id="example">ロードバランサの設定例</a></h2> 110 111 <p>技術的な詳細に入る前に例を示します。以下は、2 台のバックエンドサーバを 112 ロードバランスするための <code class="module"><a href="../mod/mod_proxy_balancer.html">mod_proxy_balancer</a></code> の使い方の一例です: 113 </p> 114 115 <div class="example"><p><code> 116 <Proxy balancer://mycluster><br /> 117 BalancerMember http://192.168.1.50:80<br /> 118 BalancerMember http://192.168.1.51:80<br /> 119 </Proxy><br /> 120 ProxyPass /test balancer://mycluster 121 </code></p></div> 122 123 <p>別の例として、<code class="module"><a href="../mod/mod_headers.html">mod_headers</a></code> を使ってスティッキネス 124 を実現するロードバランサの設定例を示します。バックエンドのサーバが 125 適切なセッションクッキーをセットしなくても動作します。 126 </p> 127 128 <div class="example"><p><code> 129 Header add Set-Cookie "ROUTEID=.%{BALANCER_WORKER_ROUTE}e; path=/" 130 env=BALANCER_ROUTE_CHANGED<br /> 131 <Proxy balancer://mycluster><br /> 132 BalancerMember http://192.168.1.50:80 route=1<br /> 133 BalancerMember http://192.168.1.51:80 route=2<br /> 134 ProxySet stickysession=ROUTEID<br /> 135 </Proxy><br /> 136 ProxyPass /test balancer://mycluster 137 </code></p></div> 138 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> 139 <div class="section"> 140 <h2><a name="requests" id="requests">Request Counting アルゴリズム</a></h2> 141 142 <p><code>lbmethod=byrequests</code> で有効になります。 143 このスケジューラの背景にある考え方は、様々なワーカーがそれぞれ、 144 設定されている分担リクエスト数をきちんと受け取れるように、 145 リクエストを扱うという考え方です。次のように動作します:</p> 146 147 <p><dfn>lbfactor</dfn> は、<em>どの程度ワーカーに仕事を振るか</em> 148 つまり<em>ワーカーのクオータ</em>を指します。この値は "分担" 149 量を表す正規化された値です。</p> 150 151 <p><dfn>lbstatus</dfn> は、<em>ワーカーのクオータを満たすために 152 どのぐらい急ぎで働かなければならないか</em>を指します。</p> 153 154 <p><dfn>ワーカー</dfn>はロードバランサのメンバで、通常は、 155 サポートされるプロトコルのうちの一つを提供しているリモートホストです。 156 </p> 157 158 <p>まず個々のワーカーにワーカークオータを割り振り、どのワーカーが最も急ぎで 159 働かなければならないか (lbstatus が最大のもの) を調べます。 160 次に仕事をするようにこのワーカーを選択し、選択したワーカーの lbstatus 161 から全ワーカーに割り振ったクオータの合計を引きます。ですから、lbstatus の総量は 162 結果的に変化しません(*)し、リクエストは期待通りに分散されます。</p> 163 164 <p>あるワーカーが無効になっても、他のものは正常にスケジュールされ続けます。 165 </p> 166 167 <div class="example"><pre><code>for each worker in workers 168 worker lbstatus += worker lbfactor 169 total factor += worker lbfactor 170 if worker lbstatus > candidate lbstatus 171 candidate = worker 172 173 candidate lbstatus -= total factor</code></pre></div> 174 175 <p>バランサを次のように設定した場合:</p> 176 177 <table><tr><th>worker</th> 178 <th class="data">a</th> 179 <th class="data">b</th> 180 <th class="data">c</th> 181 <th class="data">d</th></tr> 182 <tr><th>lbfactor</th> 183 <td class="data">25</td> 184 <td class="data">25</td> 185 <td class="data">25</td> 186 <td class="data">25</td></tr> 187 <tr><th>lbstatus</th> 188 <td class="data">0</td> 189 <td class="data">0</td> 190 <td class="data">0</td> 191 <td class="data">0</td></tr> 192 </table> 193 194 <p>そして <var>b</var> が無効になった場合、次のようなスケジュールが 195 行われます。</p> 196 197 <table><tr><th>worker</th> 198 <th class="data">a</th> 199 <th class="data">b</th> 200 <th class="data">c</th> 201 <th class="data">d</th></tr> 202 <tr><th>lbstatus</th> 203 <td class="data"><em>-50</em></td> 204 <td class="data">0</td> 205 <td class="data">25</td> 206 <td class="data">25</td></tr> 207 <tr><th>lbstatus</th> 208 <td class="data">-25</td> 209 <td class="data">0</td> 210 <td class="data"><em>-25</em></td> 211 <td class="data">50</td></tr> 212 <tr><th>lbstatus</th> 213 <td class="data">0</td> 214 <td class="data">0</td> 215 <td class="data">0</td> 216 <td class="data"><em>0</em></td></tr> 217 <tr><td class="data" colspan="5">(repeat)</td></tr> 218 </table> 219 220 <p>つまりこのようにスケジュールされます: <var>a</var> <var>c</var> 221 <var>d</var> <var>a</var> <var>c</var> <var>d</var> <var>a</var> 222 <var>c</var> <var>d</var> ... 次の点に注意してください:</p> 223 224 <table><tr><th>worker</th> 225 <th class="data">a</th> 226 <th class="data">b</th> 227 <th class="data">c</th> 228 <th class="data">d</th></tr> 229 <tr><th>lbfactor</th> 230 <td class="data">25</td> 231 <td class="data">25</td> 232 <td class="data">25</td> 233 <td class="data">25</td></tr> 234 </table> 235 236 <p>この挙動は、次の設定と全く同じになります:</p> 237 238 <table><tr><th>worker</th> 239 <th class="data">a</th> 240 <th class="data">b</th> 241 <th class="data">c</th> 242 <th class="data">d</th></tr> 243 <tr><th>lbfactor</th> 244 <td class="data">1</td> 245 <td class="data">1</td> 246 <td class="data">1</td> 247 <td class="data">1</td></tr> 248 </table> 249 250 <p>と言うのも、<dfn>lbfactor</dfn> の値は全て正規化されたもので、 251 他との相対値だからです。次の設定では:</p> 252 253 <table><tr><th>worker</th> 254 <th class="data">a</th> 255 <th class="data">b</th> 256 <th class="data">c</th></tr> 257 <tr><th>lbfactor</th> 258 <td class="data">1</td> 259 <td class="data">4</td> 260 <td class="data">1</td></tr> 261 </table> 262 263 <p>ワーカー <var>b</var> は、平均して、<var>a</var> と <var>c</var> 264 の 4 倍の数のリクエストを受け持つことになります。</p> 265 266 <p>次のような非対称な設定では、こうなると予想されるでしょう:</p> 267 268 <table><tr><th>worker</th> 269 <th class="data">a</th> 270 <th class="data">b</th></tr> 271 <tr><th>lbfactor</th> 272 <td class="data">70</td> 273 <td class="data">30</td></tr> 274 <tr><td class="data" colspan="2"> </td></tr> 275 <tr><th>lbstatus</th> 276 <td class="data"><em>-30</em></td> 277 <td class="data">30</td></tr> 278 <tr><th>lbstatus</th> 279 <td class="data">40</td> 280 <td class="data"><em>-40</em></td></tr> 281 <tr><th>lbstatus</th> 282 <td class="data"><em>10</em></td> 283 <td class="data">-10</td></tr> 284 <tr><th>lbstatus</th> 285 <td class="data"><em>-20</em></td> 286 <td class="data">20</td></tr> 287 <tr><th>lbstatus</th> 288 <td class="data"><em>-50</em></td> 289 <td class="data">50</td></tr> 290 <tr><th>lbstatus</th> 291 <td class="data">20</td> 292 <td class="data"><em>-20</em></td></tr> 293 <tr><th>lbstatus</th> 294 <td class="data"><em>-10</em></td> 295 <td class="data">10</td></tr> 296 <tr><th>lbstatus</th> 297 <td class="data"><em>-40</em></td> 298 <td class="data">40</td></tr> 299 <tr><th>lbstatus</th> 300 <td class="data">30</td> 301 <td class="data"><em>-30</em></td></tr> 302 <tr><th>lbstatus</th> 303 <td class="data"><em>0</em></td> 304 <td class="data">0</td></tr> 305 <tr><td class="data" colspan="3">(repeat)</td></tr> 306 </table> 307 308 <p>スケジュールは 10 スケジュール後に繰り返され、<var>a</var> 7 回と 309 <var>b</var> 3 回でまばらに選ばれます。</p> 310 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> 311 <div class="section"> 312 <h2><a name="traffic" id="traffic">Weighted Traffic Counting アルゴリズム</a></h2> 313 314 <p><code>lbmethod=bytraffic</code> で有効になります。 315 このスケジューラの背景にある考え方は、Request Counting 316 と非常に似ていますが、次の違いがあります:</p> 317 318 <p><dfn>lbfactor</dfn> は <em>どれだけのバイト数のトラフィック量を、 319 このワーカーに処理してもらいたいか</em> を表します。 320 この値も同様に正規化された値で、ワーカー全体のうちでの "分担" 321 量を表現しています。リクエスト数を単純に数える代わりに、 322 どれだけの転送量を処理したかを数えます。</p> 323 324 <p>次のようにバランサを設定した場合:</p> 325 326 <table><tr><th>worker</th> 327 <th class="data">a</th> 328 <th class="data">b</th> 329 <th class="data">c</th></tr> 330 <tr><th>lbfactor</th> 331 <td class="data">1</td> 332 <td class="data">2</td> 333 <td class="data">1</td></tr> 334 </table> 335 336 <p><var>b</var> には <var>a</var> や <var>c</var> の 2 倍 337 処理してほしいということになります。 338 <var>b</var> は 2 倍の I/O を処理するという意味になり、 339 2 倍のリクエスト数を処理するということにはなりません。 340 ですからリクエストとレスポンスのサイズが、 341 重み付けと振り分けのアルゴリズムに効いています。</p> 342 343 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> 344 <div class="section"> 345 <h2><a name="busyness" id="busyness">Pending Request Counting アルゴリズム</a></h2> 346 347 348 349 <p><code>lbmethod=bybusyness</code> で有効になります。このスケジューラは 350 現在どのぐらいのリクエストが個々のワーカーにアサインされているかを把握しています。 351 新しいリクエストは、最も処理途中のリクエスト数が少ないワーカーに 352 自動的に割り振られます。これは、ワーカーが Apache と無関係に入力リクエストを 353 キューに溜め込む場合に有効で、キューの長さを同程度に維持しつつも、 354 最も早く処理できそうなワーカーに常にリクエストを割り振ります。</p> 355 356 <p>複数のワーカーが最少の処理中リクエスト数で並んだ場合、Request Counting 357 アルゴリズムと同じ統計情報(と重み付け)を使って順番を決めます。 358 時間が経つと、割り振りの割合は <code>byrequests</code> と似たような 359 傾向を示すようになるでしょう。</p> 360 361 <p>このアルゴリズムは Apache HTTP サーバ 2.2.10以降で利用可能です。</p> 362 363 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> 364 <div class="section"> 365 <h2><a name="environment" id="environment">エクスポートされる環境変数</a></h2> 366 367 <p>現在、6 つの環境変数がエクスポートされます:</p> 368 369 <dl> 370 371 <dt><var><a name="balancer_session_sticky" id="balancer_session_sticky">BALANCER_SESSION_STICKY</a></var></dt> 372 <dd> 373 <p>現在のリクエストに使われる <var>stickysession</var> 値になります。 374 スティッキーセッションのためのクッキー名もしくはリクエストパラメータ名です。</p> 375 </dd> 376 377 378 <dt><var><a name="balancer_session_route" id="balancer_session_route">BALANCER_SESSION_ROUTE</a></var></dt> 379 <dd> 380 <p>現在のリクエストをパースして得られる <var>route</var> 値です。</p> 381 </dd> 382 383 384 <dt><var><a name="balancer_name" id="balancer_name">BALANCER_NAME</a></var></dt> 385 <dd> 386 <p>現在のリクエストが使うバランサ名です。<code>balancer://foo</code> 387 のような値です。</p> 388 </dd> 389 390 391 <dt><var><a name="balancer_worker_name" id="balancer_worker_name">BALANCER_WORKER_NAME</a></var></dt> 392 <dd> 393 <p>現在のリクエストが使うワーカー名です。<code>http://hostA:1234</code> 394 のような値です。</p> 395 </dd> 396 397 398 <dt><var><a name="balancer_worker_route" id="balancer_worker_route">BALANCER_WORKER_ROUTE</a></var></dt> 399 <dd> 400 <p>現在のリクエストが使うワーカーの <var>route</var> 値です。</p> 401 </dd> 402 403 404 <dt><var><a name="balancer_route_changed" id="balancer_route_changed">BALANCER_ROUTE_CHANGED</a></var></dt> 405 <dd> 406 <p>セッションルートとワーカールートが一致しない時 (BALANCER_SESSION_ROUTE != BALANCER_WORKER_ROUTE) 407 あるいは、セッションがまだルートを確立していない時、値が 1 になります。 408 スティッキーセッションを使う時、ルートの更新をクライアントに送る必要があるかを 409 判断するためにこの環境変数を使えます。</p> 410 </dd> 411 </dl> 412 413 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> 414 <div class="section"> 415 <h2><a name="balancer_manager" id="balancer_manager">バランサマネージャのサポートを有効にする</a></h2> 416 417 <p>このモジュールは <code class="module"><a href="../mod/mod_status.html">mod_status</a></code> のサービスを 418 <em>必要とします</em>。 419 バランサマネージャを使うと、バランサのメンバーの動的な更新が 420 できます。バランサマネージャを使って、バランス係数 (lbfactor) 421 を変更したり、メンバーを変更したり、特定のメンバーを 422 オフラインモードにしたりできます。</p> 423 424 <p>ですから、ロードバランサ管理機能を使いたければ、 425 <code class="module"><a href="../mod/mod_status.html">mod_status</a></code> と <code class="module"><a href="../mod/mod_proxy_balancer.html">mod_proxy_balancer</a></code> 426 をサーバに組み込まなければなりません。</p> 427 428 <p>example.com ドメインのブラウザからロードバランサ管理機能を 429 使えるようにするには、次のようなコードを <code>httpd.conf</code> 430 に追加します。</p> 431 <div class="example"><p><code> 432 <Location /balancer-manager><br /> 433 SetHandler balancer-manager<br /> 434 <br /> 435 Order Deny,Allow<br /> 436 Deny from all<br /> 437 Allow from .example.com<br /> 438 </Location> 439 </code></p></div> 440 441 <p>こうすると、<code>http://your.server.name/balancer-manager</code> 442 のページ経由で、ウェブブラウザからロードバランサマネージャに 443 アクセスできるようになります。</p> 444 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> 445 <div class="section"> 446 <h2><a name="stickyness_implementation" id="stickyness_implementation">ロードバランサのスティッキネスの詳細</a></h2> 447 448 <p>クッキーをもとにスティッキネスを使う場合、どのバックエンドに割り振るべきか 449 を決めるクッキーの名前を指定する必要があります。 450 クッキー名は <code class="directive"><a href="../mod/mod_proxy.html#proxypass">ProxyPass</a></code> または 451 <code class="directive"><a href="../mod/mod_proxy.html#proxyset">ProxySet</a></code> のいずれか 452 に付与する <var>stickysession</var> 属性で設定します。 453 クッキー名は大文字小文字を区別します。 454 バランサはそのクッキーの値を取り出し、その値に一致する <var>route</var> 値の 455 ワーカーを探します。 456 <var>route</var> も <code class="directive"><a href="../mod/mod_proxy.html#proxypass">ProxyPass</a></code> 457 または <code class="directive"><a href="../mod/mod_proxy.html#proxyset">ProxySet</a></code> 458 のいずれかに設定しなければいけません。 459 クッキーはバックエンドによって設定されるか、あるいは 460 上記の <a href="#example">例</a> のように Apache Web サーバ自身 461 によって設定されます。</p> 462 <p>バックエンドの中の一部は少し異なる形式のスティッキネスクッキーを使います。 463 たとえば Apache Tomcat がそうです。Tomcat は自身のインスタンス名を 464 セッション ID のクッキーの最後に付け加えます。この時、セッション ID 465 との区切り文字にドット (<code>.</code>) を使います。 466 このため、Apache Web サーバがドットをスティッキネスクッキー値の中に見つけると、 467 route を探すためにドット以降の部分のみを使うようにします。 468 Tomcat 側で自身のインスタンス名を設定するには、Tomcat の設定ファイル 469 <code>conf/server.xml</code> の中の <code>jvmRoute</code> 属性に 470 指定する必要があります。値はそれぞれの Tomcat に接続するワーカーの 471 <var>route</var> 値と一致させます。 472 Tomcat およびサーブレットベースの Java Web アプリサーバが一般に使う 473 セッションクッキーの名前は <code>JSESSIONID</code> (すべて大文字) です。 474 この名前は設定により変更も可能です。</p> 475 <p>スティッキネスを実装するふたつめの手段は URL エンコーディングです。 476 Web サーバはリクエストの URL の中からクエリパラメータを探します。 477 探すパラメータ名は同じように <var>stickysession</var> 属性で指定します。 478 パラメータ値と一致する <var>route</var> 値のワーカーを探します。 479 レスポンスに含まれるすべての URL リンクを探しだし書き換えるのは簡単ではないので、 480 一般にそれぞれのリンクにクエリパラメータを付け加えるのは、 481 そのコンテンツを生成したバックエンドの仕事です。 482 時には、<code class="module"><a href="../mod/mod_substitute.html">mod_substitute</a></code> を使って Web サーバにこの書き換えを 483 させるのが可能な場合もあります。 484 ただし、パフォーマンスを落とす可能性があります。</p> 485 <p>Java 標準は URL エンコーディングを少し異なる形で実装します。 486 URL のパス情報をセミコロン (<code>;</code>) で区切って 487 セッション ID を付け加えます。 488 クッキーの場合と同じように、 Apache Tomcat はこのパス情報に 489 <code>jvmRoute</code> の設定値を含めます。 490 Apache にこの種のパス情報を見つけさせるには、 491 <code class="directive"><a href="../mod/mod_proxy.html#proxypass">ProxyPass</a></code> あるいは 492 <code class="directive"><a href="../mod/mod_proxy.html#proxyset">ProxySet</a></code> の 493 <code>scolonpathdelim</code> を <code>On</code> にします。</p> 494 <p>最後に、クッキーと URL エンコーディングの両方が指定できることを示します。 495 次の例のように、クッキー名と URL パラメータ名を垂直バー (<code>|</code>) 496 で区切って指定します:</p> 497 <div class="example"><p><code> 498 ProxyPass /test balancer://mycluster stickysession=JSESSIONID|jsessionid scolonpathdelim=On<br /> 499 <Proxy balancer://mycluster><br /> 500 BalancerMember http://192.168.1.50:80 route=node1<br /> 501 BalancerMember http://192.168.1.51:80 route=node2<br /> 502 </Proxy><br /> 503 </code></p></div> 504 <p>もし同じリクエストが、クッキーとリクエストパラメータの両方のルーティング情報を 505 提供した場合、リクエストパラメータのほうが使われます。</p> 506 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div> 507 <div class="section"> 508 <h2><a name="stickyness_troubleshooting" id="stickyness_troubleshooting">ロードバランサのスティッキネスのトラブルシューティング</a></h2> 509 510 <p>もしアプリのセッションが失われてユーザが再ログインしなければいけないなど 511 スティッキネス関連のエラーに遭遇したら、 512 この原因はバックエンドの応答に支障があったせいか、 513 あるいは設定ミスによるものかを最初に切り分けたいでしょう。 514 バックエンドの安定性に関して起きうる問題を見つけるには、 515 Apache のエラーログにプロキシエラーのメッセージがないか確認してください。</p> 516 <p>設定が正しいかを確認するには、最初にスティッキネスを 517 クッキーと URL エンコーディングのどちらで行っているかを確認してください。 518 次に、<code class="directive"><a href="../mod/mod_log_config.html#logformat">LogFormat</a></code> を変更して 519 アクセスログに適切なデータが残るようにするとよいでしょう。 520 次のフィールドが便利です:</p> 521 <dl> 522 <dt><code>%{MYCOOKIE}C</code></dt> 523 <dd><code>MYCOOKIE</code> という名前のクッキーの値。 524 この名前は <var>stickysession</var> 属性の指定値と同じはずです。</dd> 525 <dt><code>%{Set-Cookie}o</code></dt> 526 <dd>これによりバックエンドがセットするクッキーをログに出せます。 527 バックエンドが期待するセッションクッキーをセットしているかと、 528 どんな値がセットされているかを追跡できます。</dd> 529 <dt><code>%{BALANCER_SESSION_STICKY}e</code></dt> 530 <dd>ルーティング情報を決めるために使われたクッキー名もしくは 531 リクエストパラメータ名。</dd> 532 <dt><code>%{BALANCER_SESSION_ROUTE}e</code></dt> 533 <dd>リクエスト内に見つかった route 値の情報</dd> 534 <dt><code>%{BALANCER_WORKER_ROUTE}e</code></dt> 535 <dd>選択されたワーカーの route 値</dd> 536 <dt><code>%{BALANCER_ROUTE_CHANGED}e</code></dt> 537 <dd>リクエストの route 値がワーカーの route 値と異なる場合に 538 <code>1</code> になります。つまり、リクエストはスティッキーとして 539 処理されていません。</dd> 540 </dl> 541 <p>セッションが失われる原因でよくあるものは、セッションタイムアウトですが、 542 これは通常バックエンドのサーバで変更可能です。</p> 543 <p>ログレベルを <code>debug</code> 以上に設定すると、 544 バランサはスティッキネス動作の詳細な情報をエラーログに書き出します。 545 これはスティッキネスの問題のトラブルシューティングする簡単な手法ですが、 546 高負荷な本番サーバではログの分量が膨大になってしまうかもしれません。</p> 547 </div> 548 </div> 549 <div class="bottomlang"> 550 <p><span>翻訳済み言語: </span><a href="../en/mod/mod_proxy_balancer.html" hreflang="en" rel="alternate" title="English"> en </a> | 551 <a href="../ja/mod/mod_proxy_balancer.html" title="Japanese"> ja </a></p> 552 </div><div class="top"><a href="#page-header"><img src="../images/up.gif" alt="top" /></a></div><div class="section"><h2><a id="comments_section" name="comments_section">コメント</a></h2><div class="warning"><strong>Notice:</strong><br />This is not a Q&A section. Comments placed here should be pointed towards suggestions on improving the documentation or server, and may be removed again by our moderators if they are either implemented or considered invalid/off-topic. Questions on how to manage the Apache HTTP Server should be directed at either our IRC channel, #httpd, on Freenode, or sent to our <a href="http://httpd.apache.org/lists.html">mailing lists</a>.</div> 553 <script type="text/javascript"><!--//--><![CDATA[//><!-- 554 var comments_shortname = 'httpd'; 555 var comments_identifier = 'http://httpd.apache.org/docs/2.2/mod/mod_proxy_balancer.html'; 556 (function(w, d) { 557 if (w.location.hostname.toLowerCase() == "httpd.apache.org") { 558 d.write('<div id="comments_thread"><\/div>'); 559 var s = d.createElement('script'); 560 s.type = 'text/javascript'; 561 s.async = true; 562 s.src = 'https://comments.apache.org/show_comments.lua?site=' + comments_shortname + '&page=' + comments_identifier; 563 (d.getElementsByTagName('head')[0] || d.getElementsByTagName('body')[0]).appendChild(s); 564 } 565 else { 566 d.write('<div id="comments_thread">Comments are disabled for this page at the moment.<\/div>'); 567 } 568 })(window, document); 569 //--><!]]></script></div><div id="footer"> 570 <p class="apache">Copyright 2017 The Apache Software Foundation.<br />この文書は <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a> のライセンスで提供されています。.</p> 571 <p class="menu"><a href="../mod/">モジュール</a> | <a href="../mod/directives.html">ディレクティブ</a> | <a href="http://wiki.apache.org/httpd/FAQ">FAQ</a> | <a href="../glossary.html">用語</a> | <a href="../sitemap.html">サイトマップ</a></p></div><script type="text/javascript"><!--//--><![CDATA[//><!-- 572 if (typeof(prettyPrint) !== 'undefined') { 573 prettyPrint(); 574 } 575 //--><!]]></script> 576 </body></html>