|
||||||||||||
| 前のページ 1 2 3 4 次のページ | ||||||||||||
| Tomcatクラスタリングのアーキテクチャ | ||||||||||||
|
Tomcatクラスタリングの各機能であるロードバランス、フェイルオーバー、ファーミングを実現するためのアーキテクチャについて説明します。 |
||||||||||||
| ロードバランス | ||||||||||||
|
Tomcatでロードバランスを行うには、表1のようなロードバランサを使うことになります。
表1:ロードバランサ それぞれに特徴がありますが、本連載ではApache+mod_jkをTomcatクラスタのロードバランサとする1を用います。一般的にTomcatでロードバランス機能を有効にするには、Apacheのプラグインとしてmod_jkを使用することが多いです。 ここではApacheを用いますが、そもそもJKコネクタはTomcatとWebサーバの連携のために、Tomcatとともに開発されているプロジェクトであり、Apache以外の様々なWebサーバ用のモジュールがあります。それらはJakartaのWebサイトからダウンロードできます。 JKコネクタのApache用モジュールであるmod_jkをApacheに組み込むことによって、クライアントからのリクエストを設定ファイル(workers.properties)に基づいて適切なTomcatへ転送できるようになります。 mod_jkはHTTPよりパフォーマンスを向上させることを狙ってAJP1.3というプロトコルを用いています。AJPプロトコルはバイナリフォーマットでデータ転送を行い、WebサーバはサーブレットコンテナとTCP接続で通信を行います。 TCPソケットを作成することはコストが高くつき、パフォーマンスが低下してしまうため、複数のリクエスト・レスポンスで使用する永続的な接続をキープできるようになっています。詳細な説明はJakartaのサイトにありますので、そちらを参照してください。
Jakarta Tomcat Connector - AJPv13
http://jakarta.apache.org/tomcat/connectors-doc/common/ajpv13a.html Tomcatのデフォルトの"server.xml"でもAJPプロトコルを受けつけることができるようになっており、「Connector」要素にその設定が記述されています。デフォルトの設定ではポート8080でHTTPを、ポート8009でAJPを受けつける設定になっています。 ロードバランスでは、すべてのサーバに対して順番に1回ずつリクエストを割り振る方法であるラウンドロビンというロジックが基本的に用いられますが、"workers.properties"の"lbfactor"というパラメータでサーバごとに割り振られるリクエストの割り合いを設定することが可能です。 クライアントからのリクエストを受けつけたサーバに、以降も同じクライアントからのリクエストを処理させたい場合がでてくることがあります。このような場合はスティッキーセッションを使うことができます。 スティッキーセッションとは「同一のセッションを保っているあいだは同じサーバにリクエストを割り当て続ける」という方法です。HTTPリクエスト/HTTPレスポンスが保持するセッションID(CookieあるいはURLに記述されています)の最後尾に使用するTomcatサーバ固有の文字列を付加することで、mod_jkがリクエストを振るべきTomcatサーバの決定を可能にします。 スティッキーセッションを有効にするには"workers.properties"の"sticky_session"をtrueに設定しておく必要があります。 |
||||||||||||
|
前のページ 1 2 3 4 次のページ |
||||||||||||
|
|
||||||||||||
|
|
||||||||||||
|
||||||||||||
|
|
||||||||||||
|
||||||||||||


