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="&lt;-" alt="&lt;-" src="../images/left.gif" /></a></div>
    24  <div id="path">
    25  <a href="http://www.apache.org/">Apache</a> &gt; <a href="http://httpd.apache.org/">HTTP サーバ</a> &gt; <a href="http://httpd.apache.org/docs/">ドキュメンテーション</a> &gt; <a href="../">バージョン 2.2</a> &gt; <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">&nbsp;en&nbsp;</a> |
    32  <a href="../ja/mod/mod_proxy_balancer.html" title="Japanese">&nbsp;ja&nbsp;</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      &lt;Proxy balancer://mycluster&gt;<br />
   117  	BalancerMember http://192.168.1.50:80<br />
   118  	BalancerMember http://192.168.1.51:80<br />
   119      &lt;/Proxy&gt;<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      &lt;Proxy balancer://mycluster&gt;<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      &lt;/Proxy&gt;<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 &gt; 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">&nbsp;</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      &lt;Location /balancer-manager&gt;<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      &lt;/Location&gt;
   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      &lt;Proxy balancer://mycluster&gt;<br />
   500      BalancerMember http://192.168.1.50:80 route=node1<br />
   501      BalancerMember http://192.168.1.51:80 route=node2<br />
   502      &lt;/Proxy&gt;<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">&nbsp;en&nbsp;</a> |
   551  <a href="../ja/mod/mod_proxy_balancer.html" title="Japanese">&nbsp;ja&nbsp;</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&amp;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>