ヘッダーをスキップ
Oracle® Fusion Middleware Oracle Coherence*WebでのHTTPセッション・マネージメントの管理
12c (12.1.2)
B70746-02
  ドキュメント・ライブラリへ移動
ライブラリ
製品リストへ移動
製品
目次へ移動
目次

前
 
次
 

4 他のアプリケーション・サーバーにおけるCoherence*Webの使用方法

この章では、様々なアプリケーション・サーバーで使用するために、Coherence*Web、セッション状態の永続性および管理モジュールを構成してデプロイする方法について説明します。Coherence*Webをこれらのアプリケーション・サーバーで使用可能にする機能は、自動化されたCoherence*Web WebInstallerを実行することにより提供されます。


準備:

「サポートされているWebコンテナ」を参照して、アプリケーション・サーバー固有のインストール手順を実行する必要があるかどうかを確認してください。

WebLogic Server上でCoherence*Webをデプロイするには、次の方法があります。


この章では、Coherence*Web WebInstallerを使用して、Java EEアプリケーション向けのCoherence*Webを様々なアプリケーション・サーバーにインストールする手順について説明します。

この章には次の項が含まれます:

4.1 WebInstallerによるCoherence*Webのインストール

Coherence*Webは、様々なWebコンテナのJava EEアプリケーションに対して有効化できます。これを行うには、アプリケーションをデプロイする前に、自動化したCoherence*Web WebInstallerを使用して、デプロイの準備が整ったアプリケーションを実行する必要があります。この自動化したインストーラによって、アプリケーションのデプロイメント準備が完了します。インスペクトとインストールの2段階でインストール・プロセスが実行されます。これらの各段階でのインストーラの動作は、「Coherence*Web WebInstallerによるJava EEアプリケーションの設定」を参照してください。

このインストーラは、JavaコマンドラインまたはAntタスクから実行できます。次の各項では、Javaコマンドラインから実行する方法について説明します。Antタスク・ベースのインストールについては、「Coherence*Web WebInstaller Antタスク」を参照してください。

4.1.1 アプリケーション・サーバー固有のインストール手順

「サポートされているWebコンテナ」の説明にあるすべてのWebコンテナは、WebInstallerで同じ一般的なインストール手順を使用してインストールできます。この手順の詳細は「Coherence*Webセッション管理モジュールをインストールする一般的な手順」を参照してください。

Webコンテナの中には、この一般的なインストール手順を開始する前に、そのコンテナ固有の追加手順を実行しなければならないものがわずかにあります。Caucho Resin、WebLogic 10.nなどがこのようなコンテナに該当します。次の各項で、アプリケーション・サーバー固有のインストール手順について説明しています。

4.1.1.1 Oracle WebLogic Server 10.nへのインストール

Coherence*Webセッション管理モジュールをOracle WebLogic Serverリリース10からリリース10.2にインストールするには、次の手順を実行します。

  1. coherence-web.jarファイルをcoherence/libディレクトリから入手します。

  2. サーバー・クラスタで実行する予定のWebLogic Server 10.nをインストールするたびに、次のコマンドを使用してライブラリを更新します。

    java -cp coherence.jar;coherence-web.jar com.tangosol.coherence.servlet.WebPluginInstaller <wls-home-path> -install
    
  3. 「Coherence*Webセッション管理モジュールをインストールする一般的な手順」の説明にある手順に従ってインストールを完了します。サーバー・タイプとして「WebLogic/10.x」を指定します。

4.1.1.2 Caucho Resin 3.1.nへのインストール

Coherence*Webセッション管理モジュールをCaucho Resin 3.1.nサーバーにインストールするには、次の手順を実行します。

  1. coherence-web.jarファイルをcoherence/libディレクトリから入手します。

  2. サーバー・クラスタで実行する予定のCaucho Resinをインストールするたびに、次のコマンドを使用してライブラリを更新します。

    java -cp coherence.jar;coherence-web.jar 
    com.tangosol.coherence.servlet.WebPluginInstaller <resin-home-path> -install 
    
  3. 「Coherence*Webセッション管理モジュールをインストールする一般的な手順」の説明にある手順に従ってインストールを完了します。サーバー・タイプとして「Resin/3.1.x」を指定します。

4.1.2 Coherence*Webセッション管理モジュールをインストールする一般的な手順

サポートされているWebコンテナ」に記載したどのWebコンテナにJava EEアプリケーション用のCoherence*Webをインストールする場合でも、次の手順を実行してください。

Java EE用のCoherence*WebをApache Tomcatサーバーにインストールしている場合の手順の詳細は、「Apache Tomcatサーバーに対するスティッキー・セッションの有効化」も参照してください。

Java EE用のCoherence*WebをIBM WebSphereサーバーにインストールしている場合の手順の詳細は、「IBM WebSphere 7.nサーバーに対するURLセッションIDのデコード」も参照してください。

デプロイするJava EEアプリケーション用のCoherence*Webをインストールするには:

  1. アプリケーション・ディレクトリ、EARファイルおよびWARファイルを他のプロセスで使用もアクセスもしていないことを確認します。

  2. 現在のディレクトリをCoherenceのライブラリ・ディレクトリに変更します(Windowsの場合は%COHERENCE_HOME%\lib、Unixの場合は$COHERENCE_HOME/lib)。

  3. Javaコマンドを実行できるようにパスを構成していることを確認します。

  4. 次のコマンドを実行してアプリケーションのインスペクト手順を完了します。次のコマンドラインで、<app-path>にはアプリケーションへのフル・パスを指定し、<server-type>には、使用しているサーバーの名前を表1-1から選択して指定します。

    java -jar webInstaller.jar <app-path> -inspect -server:<server-type>
    

    アプリケーションを配置したディレクトリに、Java EEアプリケーション用のcoherence-web.xml構成ディスクリプタ・ファイルが作成されます(すでに存在している場合はそれが更新されます)。この構成ディスクリプタ・ファイルには、アプリケーション用としてインストーラ推奨のデフォルトのCoherence*Web設定が収められています。

  5. 必要に応じて、各自の要件に基づいてCoherence*Web設定を見直し、変更してください。

    coherence-web.xmlディスクリプタ・ファイルを編集することで、Coherence*Web設定を変更できます。変更可能なCoherence*Web設定は、付録A「Coherence*Webコンテキスト・パラメータ」を参照してください。context-paramパラメータのサブ要素であるparam-nameおよびparam-valueを使用して、必要な機能を有効にします。表4-1に、様々な設定の例を示します。

    表4-1 Coherence*Webのコンテキスト・パラメータ設定の例

    パラメータ 名前 説明

    coherence-servletcontext-clustered

    true

    すべてのServletContext(グローバル)属性をクラスタ化し、そのクラスタにあるサーバーがこれらの属性に同じ値を持ち、これらの属性が変更されたときはサーブレット仕様で指定されたイベントを受け取るようにします。

    coherence-enable-sessioncontext

    true

    アプリケーションで使用すると、そのアプリケーションに存在するすべてのセッションを列挙したり、そのいずれかを取得して調査または操作したりできます。

    coherence-session-id-length

    32

    SecureRandomアルゴリズムを使用して生成したHttpSession IDを長くできます。この長さは任意の値にできますが、実際は、CookieまたはURLに適した長さにする必要があります(セッションIDの管理方法に依存)。これを長くすると、セッションが意図的にハイジャックされる危険性を低くできます。

    coherence-session-urlencode-enabled

    true

    デフォルトでは、HttpSession IDはCookieで管理されます。アプリケーションでURLのエンコードがサポートされている場合、このオプションにより有効になります。


  6. 次のコマンドで、<app-path>をアプリケーションへのフル・パスに置き換えて実行すると、Coherence*Webアプリケーションのインストール手順が実行します。

    java -jar webInstaller.jar <app-path> -install
    

    このインストーラでは、有効なcoherence-web.xml構成ディスクリプタ・ファイルをアプリケーションと同じディレクトリに配置する必要があります。このコマンドにより、アプリケーション・アーカイブ・ファイルのWEB-INF\classesディレクトリにdefault-session-cache-config.xmlファイルが作成されます。このファイルには、セッション構成情報とキャッシュ構成情報が格納されます。

  7. 更新済のアプリケーションをデプロイし、Coherenceディストリビューションに付随している軽量型ロード・バランサを使用して、すべてが仕様どおりに機能することを確認します。この軽量型ロード・バランサは、WebLogic Serverに付随しているロード・バランサとは対照的に、本番向けのユーティリティではありません。

Coherenceでサポートしているデプロイメント・トポロジであれば任意のトポロジで、アプリケーションをデプロイして実行できます。サポートしているデプロイメント・トポロジには、Coherence*Extendによるアウトオブプロセスとインプロセスがあります。これらのトポロジにおいてアプリケーションのデプロイと実行を行う方法の詳細は、次の各項を参照してください。トポロジ自体の詳細は、「デプロイメント・トポロジ」を参照してください。

4.1.2.1 インプロセスのアプリケーションのデプロイと実行

Coherence*Webはアプリケーション・サーバーでインプロセス状態で実行できます。これは、セッション・データがアプリケーション・サーバーで格納される場所です。このトポロジの詳細は、「インプロセス・トポロジ」を参照してください。

アプリケーション・サーバーの場合:

  1. 記憶域を有効化した状態でアプリケーション・サーバーを起動します。システム・プロパティのtangosol.coherence.session.localstorage=trueをアプリケーション・サーバー起動スクリプトのJavaオプションに追加します。

  2. coherence.jarcoherence-web.jarのファイルを共有ライブラリとしてデプロイします。

  3. アプリケーションをデプロイして実行します。

4.1.2.2 アウトオブプロセスのアプリケーションのデプロイと実行

アウトオブプロセス・デプロイメント・トポロジでは、スタンドアロンのキャッシュ・サーバーでセッション・データを格納し、アプリケーション・サーバーはキャッシュ・クライアントとして構成されます。このトポロジの詳細は、「アウトオブプロセス・トポロジ」を参照してください。

キャッシュ・サーバーとアプリケーション・サーバーは、同じキャッシュ構成とセッション構成を使用する必要があります。この構成は、Coherence*Web WebInstallerによりdefault-session-cache-config.xmlファイルに生成されます。WebInstallerにより、設定済アプリケーションのWEB-INF\classesディレクトリにファイルが生成されます。

キャッシュ・サーバーの場合:

  1. tangosol.coherence.cacheconfigシステム・プロパティをキャッシュ・サーバー起動スクリプトに追加して、構成ファイルを探します。また、システム・プロパティのtangosol.coherence.session.localstorage=trueを含めて、キャッシュ・サーバーの記憶域を有効にする必要があります。

  2. coherence.jarcoherence-web.jarのファイルをキャッシュ・サーバー起動スクリプトのクラスパスに追加します。

    次の例は、サンプル起動スクリプトです。

    java -server -Xms512m -Xmx512m 
    -cp <Coherence installation dir>/lib/coherence.jar:<Coherence installation dir>/lib/coherence-web.jar -Dtangosol.coherence.management.remote=true -Dtangosol.coherence.cacheconfig=default-session-cache-config.xml 
    -Dtangosol.coherence.session.localstorage=true com.tangosol.net.DefaultCacheServer
    

アプリケーション・サーバーの場合(キャッシュ・クライアント):

  1. coherence.jarcoherence-web.jarのファイルを共有ライブラリとしてデプロイします。

  2. 設定済アプリケーションのWEB-INF\classesディレクトリにdefault-session-cache-config.xmlファイルが存在する必要があります。

    デフォルトでは、ファイルではローカル記憶域が無効になるように指定します(不明な場合、ファイルを調べてlocal-storage要素がfalseに設定されていることを確認するか、システム・プロパティのtangosol.coherence.session.localstorage=falseを起動スクリプトに追加できます)。

  3. アプリケーションをサーバーにデプロイします。

4.1.2.3 アウトオブプロセス・トポロジへの移行

インプロセスのCoherence*Webでアプリケーションの実行とテストを行っている場合、簡単にアウトオブプロセス・トポロジに移行できます。単純に、キャッシュ・サーバーとアプリケーション・サーバーを設定します。詳細は、「アウトオブプロセスのアプリケーションのデプロイと実行」を参照してください。

4.1.2.4 Coherence*Extendによるアウトオブプロセスのアプリケーションのデプロイと実行

Coherence*Extendによるアウトオブプロセス・トポロジは、アウトオブプロセス・トポロジに似ていますが、アプリケーション・サーバー層とキャッシュ・サーバー層との通信をCoherence*Extend経由(TCP/IP)で行う点が異なります。Coherence*Extendは、クラスタの外部で実行されるExtendクライアント(またはプロキシ)と、1台以上のキャッシュ・サーバーでホストされているクラスタ内で実行される拡張プロキシ・サービスの2つの基本コンポーネントで構成されます。このトポロジの詳細は、「"Coherence*Extendによるアウトオブプロセス・トポロジ"」を参照してください。

これらのデプロイメントの参加者には、次の3種類があります。

  • キャッシュ・サーバー(記憶域サーバー)は、実際のセッション・データをメモリーに格納する際に使用されます。

  • Web(アプリケーション)サーバーは、このトポロジにおけるExtendクライアントです。クラスタのメンバーにはならず、クラスタ内のプロキシ・ノードに接続します。クラスタへのリクエストの発行は、そのプロキシ・ノードが代行します。

  • プロキシ・サーバーは、クラスタ内の記憶域が無効なメンバーとして、ExtendクライアントからのTCP/IP接続を受け入れ、管理します。クライアントからのリクエストはクラスタに送信され、応答はTCP/IP接続を通じて返送されます。

キャッシュ・サーバーの場合:

「アウトオブプロセスのアプリケーションのデプロイと実行」でキャッシュ・サーバーを構成する手順に従ってください。また、キャッシュ・サーバーのdefault-session-cache-config.xmlファイルをコピーしてから編集し、システム・プロパティのtangosol.coherence.session.proxy=falsetangosol.coherence.session.localstorage=trueを追加します。

これらのコンテキスト・パラメータを含むdefault-session-cache-config.xmlファイルの例と詳細は、「プロキシJVMと記憶域JVMのキャッシュの構成」を参照してください。

Web層(アプリケーション)サーバーの場合:

「アウトオブプロセスのアプリケーションのデプロイと実行」でアプリケーション・サーバーを構成する手順に従ってください。また、次の手順を完了します。

  1. オプティミスティック・ロック・モードを使用するようにCoherence*Webを構成していることを確認します。オプティミスティック・ロックは、Coherence*Webにおけるデフォルトのロック・メカニズムです(「"オプティミスティック・ロック"」を参照)。

  2. アプリケーション・サーバーのdefault-session-cache-config.xmlファイルをコピーしてから編集し、プロキシJVMのホスト名、IPアドレスおよびポートを追加します。このためには、<remote-addresses>セクションをファイルに追加します。一般には、ロード・バランシングとフェイルオーバーに備えて、すべてのプロキシJVMのホスト名、IPアドレスおよびポートを追加します。

<remote-addresses>セクションを含むdefault-session-cache-config.xmlファイルの例と詳細は、「Web層JVMのキャッシュの構成」を参照してください。

プロキシ・サーバーの場合:

若干変更することで、プロキシ・サーバーではキャッシュ・サーバーおよびアプリケーション・サーバーと同じキャッシュ構成およびセッション構成を使用できます。default-session-cache-config.xmlファイルを編集して、これらのシステム・プロパティを追加します。

  • tangosol.coherence.session.localstorage=falseにより、ローカル記憶域を無効にします。

  • tangosol.coherence.session.proxy=trueは、プロキシ・サービスが使用されていることを示します。

  • tangosol.coherence.session.proxy.localhostは、プロキシがバインドされるNICのホスト名またはIPアドレスを示します。

  • tangosol.coherence.session.proxy.localportは、プロキシがバインドされるポートの一意のポート番号を示します。

これらのコンテキスト・パラメータを含むdefault-session-cache-config.xmlファイルの例と詳細は、「プロキシJVMと記憶域JVMのキャッシュの構成」を参照してください。

4.1.3 Apache Tomcatサーバーに対するスティッキー・セッションの有効化

Apache Tomcatサーバーにスティッキー・セッションを採用するには、サーバーのserver.xmlファイルにjvmRoute属性を構成する必要があります。この属性の詳細は、次のURLを参照してください。

http://tomcat.apache.org/connectors-doc/reference/workers.html

4.1.4 IBM WebSphere 7.nサーバーに対するURLセッションIDのデコード

coherence-session-urldecode-bycontainerコンテキスト・パラメータをtrueに設定すると、コンテナでURLをデコードできます。Java EE用のCoherence*WebをIBM WebSphereアプリケーション・サーバーのリリース7.nにインストールしている場合は、このコンテキスト・パラメータをfalseに設定する必要があります。WebSphereアプリケーション・サーバーのかわりに、Coherence*WebによってセッションIDのデコードが処理されます。

Coherence*Web WebInstallerをWebSphere 7.nアプリケーション・サーバー・タイプに対して実行する場合、このパラメータは、ユーザーが明示的にtrueに設定しないかぎり、自動的にfalseに設定されます。

4.2 Coherence*Web WebInstaller Antタスク

Coherence*Web WebInstaller Antタスクを使用すると、既存のAntビルド・ファイルからインストーラを実行できます。

この項の内容は次のとおりです。

4.2.1 Coherence*Web WebInstaller Antタスクの使用方法

Coherence*Web WebInstaller Antタスクを使用するには、例4-1に示すタスク・インポート文をAntビルド・ファイルに追加します。この例で、${coherence.home}はCoherenceをインストールした環境のルート・ディレクトリを指しています。

例4-1 Coherence*Web WebInstaller用のタスク・インポート文

<taskdef name="cwi" classname="com.tangosol.coherence.misc.CoherenceWebAntTask">
    <classpath>
        <pathelement location="${coherence.home}/lib/webInstaller.jar"/>
    </classpath>
</taskdef>

次の手順は、AntビルドからJava EEアプリケーションにCoherence*Webをインストールするための基本的なプロセスを示しています。

  1. いつものようにJava EEアプリケーションをビルドします。

  2. operations属性をinspectに設定して、Coherence*Web Antタスクを実行します。

  3. 生成されたCoherence*Web XMLディスクリプタ・ファイルを必要に応じて変更します。

  4. operations属性をinstallに設定して、Coherence*Web Antタスクを実行します。

反復手順のある開発作業の実行

アプリケーションで反復手順のある開発作業(JavaServer Pages (JSP)、サーブレット、静的リソースなどの変更)を実行する場合は、次のインストール・プロセスを使用します。

  1. operations属性をuninstallに、failonerror属性をfalseに、descriptor属性を「Coherence*Web WebInstaller Antタスクの使用方法」の手順2で以前生成したCoherence*Web XMLディスクリプタ・ファイルの場所にそれぞれ設定して、Coherence*Web Antタスクを実行します。

  2. いつものようにJava EEアプリケーションをビルドします。

  3. operations属性をinspectに、install属性とdescriptor属性を「Coherence*Web WebInstaller Antタスクの使用方法」の手順2で以前生成したCoherence*Web XMLディスクリプタ・ファイルの場所にそれぞれ設定して、Coherence*Web Antタスクを実行します。

Java EEアプリケーションのCoherence*Web構成設定の変更

Coherence*Webを使用するJava EEアプリケーションのCoherence*Web構成設定を変更する必要がある場合、次の手順を使用します。

  1. operations属性をuninstallに、descriptor属性をJava EEアプリケーションのCoherence*Web XMLディスクリプタ・ファイルの場所にそれぞれ設定して、Coherence*Web Antタスクを実行します。

  2. Coherence*Web XMLディスクリプタ・ファイルで、必要な構成パラメータを変更します。

  3. operations属性をinstallに、descriptor属性を「Coherence*Web WebInstaller Antタスクの使用方法」の手順2で変更したCoherence*Web XMLディスクリプタ・ファイルの場所にそれぞれ設定して、Coherence*Web Antタスクを実行します。

4.2.2 WebInstaller Antタスクの構成

表4-2は、Coherence*Web WebInstaller Antタスクで使用可能な属性を示しています。

表4-2 Coherence*Web WebInstaller Antタスクの属性

属性 説明 必須?

app

目的のJava EEアプリケーションへのパス。WARファイル、EARファイル、展開したWARディレクトリ、または展開したEARディレクトリのいずれかへのパスを指定できます。

operations属性をversion以外の値に設定した場合は、はい。

backup

元の目的のJava EEアプリケーションのバックアップを保存するディレクトリへのパス。この属性は、デフォルトでJava EEアプリケーションのインストール先ディレクトリに設定されます。

いいえ

descriptor

Coherence*Web XMLディスクリプタ・ファイルへのパス。この属性は、デフォルトで目的のJava EEアプリケーションのインストール先ディレクトリにあるcoherence-web.xmlファイルに設定されます。

いいえ

failonerror

0以外のステータスでCoherence*Webインストーラが終了した場合はAntビルドを停止します。デフォルトはtrueです。

いいえ

nowarn

警告メッセージを表示しません。この属性の値はtrueまたはfalseのいずれかです。デフォルトはfalseです。

いいえ

operations

実行する操作をカンマまたはスペースで区切って指定します。指定できる操作は、inspectinstalluninstall、およびversionです。

はい

server

目的のJava EEアプリケーション・サーバーの別名。

いいえ

touch

Coherence*Webインストーラによって変更されたJSPとTLDにtouchコマンドを実行します。この属性に指定できる値は、truefalse、またはM/d/y h:mmです。デフォルトはfalseです。

いいえ

verbose

詳細出力を表示します。この属性の値はtrueまたはfalseのいずれかです。デフォルトはfalseです。

いいえ


4.2.3 WebInstaller Antタスクの例

次に、WebInstaller Antタスクのコマンド例を示します。

  • myWebApp.war Webアプリケーションをインスペクトして、現在の作業ディレクトリでmy-coherence-web.xmlという名前のCoherence*Web XMLディスクリプタ・ファイルを作成します。

    <cwi app="myWebApp.war" operations="inspect" descriptor="my-coherence-web.xml"/>
    
  • 現在の作業ディレクトリにあるmy-coherence-web.xmlという名前のCoherence*Web XMLディスクリプタ・ファイルを使用して、myWebApp.war WebアプリケーションにCoherence*Webをインストールします。

    <cwi app="myWebApp.war" operations="install" descriptor="my-coherence-web.xml"/>
    
  • myWebApp.war WebアプリケーションからCoherence*Webをアンインストールします。

    <cwi app="myWebApp.war" operations="uninstall">
    
  • /dev/myWebApp/srcディレクトリにあるmy-coherence-web.xmlという名前のCoherence*Web XMLディスクリプタ・ファイルを使用して、/dev/myWebApp/buildディレクトリに配置したmyWebApp.war WebアプリケーションにCoherence*Webをインストールし、元のWebアプリケーションのバックアップを/dev/myWebApp/workディレクトリに配置します。

    <cwi app="/dev/myWebApp/build/myWebApp.war" operations="install" descriptor="/dev/myWebApp/src/my-coherence-web.xml" backup="/dev/myWebApp/work"/>
    
  • /dev/myWebApp/buildディレクトリにあるcoherence-web.xmlという名前のCoherence*Web XMLディスクリプタ・ファイルを使用して、/dev/myWebApp/buildディレクトリに配置したmyWebApp.war WebアプリケーションにCoherence*Webをインストールします。Webアプリケーションがまだインスペクトされていない(つまり、/dev/myWebApp/build/coherence-web.xmlが存在しない)場合は、Coherence*Webをインストールする前にWebアプリケーションをインスペクトします。

    <cwi app="/dev/myWebApp/build/myWebApp.war" operations="inspect,install"/>
    
  • /dev/myWebApp/srcディレクトリにあるmy-coherence-web.xmlという名前のCoherence*Web XMLディスクリプタ・ファイルを使用して、/dev/myWebApp/buildディレクトリに配置したmyWebApp.war WebアプリケーションにCoherence*Webを再インストールします。

    <cwi app="/dev/myWebApp/build/myWebApp.war" operations="uninstall,install" descriptor="/dev/myWebApp/src/my-coherence-web.xml"/>
    

4.3 HTTPセッション管理のテスト

Coherenceには、ソフトウェアによる軽量なロード・バランサが付属しています。このソフトウェアはテスト以外の目的には使用できません。このロード・バランサは、セッション管理などの機能テストではきわめて効果的で、たいへん使いやすいソフトウェアです。次の手順に従い、HTTPセッション管理を軽量型ロード・バランサでテストします。

  1. それぞれがIPアドレスとポートの一意な組合せでアプリケーションを実行する複数のアプリケーション・サーバー・プロセスを、1台以上のサーバー・マシン上で開始します。

  2. コマンド(またはシェル)ウィンドウを開きます。

  3. 現在のディレクトリをCoherenceのライブラリ・ディレクトリに変更します(Windowsの場合は%COHERENCE_HOME%\lib、Unixの場合は$COHERENCE_HOME/lib)。

  4. Javaコマンドを実行できるようにパスを構成していることを確認します。

  5. 次のコマンドラインを使用してソフトウェア・ロード・バランサを起動します(これらの各コマンドラインによって、デフォルトのHTTPポート80でアプリケーションが使用可能になります)。

    たとえば、2つのアプリケーション・サーバー・インスタンスを7001ポートと7002ポートに持つ1台のマシンでローカルにロード・バランシングをテストするには、次のように入力します。

    java -jar coherence-loadbalancer.jar localhost:80 localhost:7001 localhost:7002
    

    server1server2およびserver3に対して7001ポートで負荷を分散するserver1でローカルにロード・バランサを実行するには、次のように入力します。

    java -jar coherence-loadbalancer.jar server1:80 server1:7001 server2:7001 server3:7001
    

    前述のコマンドラインを実行すると、これまでhttp://server1:7001/my.jspをURLとしていたアプリケーションに、http://server1:80/my.jspまたはhttp://server1/my.jspのみを指定してアクセスできるようになります。


    注意:

    アプリケーションで使用されるアドレスが、相対リダイレクトまたはロード・バランサのアドレスのいずれかであることを確認してください。


    表4-3は、ロード・バランサのコマンドライン・オプションを示しています。

    表4-3 ロード・バランサのコマンドライン・オプション

    オプション 説明

    backlog

    TCP/IP受入れバックログ・オプションを指定の値に設定します(例: -backlog=64)。

    random

    ランダム・ロード・バランシング・アルゴリズムの使用を指定します(デフォルト)。

    roundrobin

    ラウンドロビン・ロード・バランシング・アルゴリズムの使用を指定します。

    threads

    指定の数のリクエスト・スレッドやレスポンス・スレッドのペアを使用します(そのため、新しいデーモン・スレッドの総数は指定した値の2倍になります)(例: -threads=64)。


4.4 Coherence*Web WebInstallerによるJava EEアプリケーションの設定

インスペクトの手順では、Coherence*Web WebInstallerによって次のタスクが実行されます。

  1. アプリケーションと目的のWebコンテナに関する基本的な情報、および目的のWebコンテナに適したデフォルトのCoherence*Web構成コンテキスト・パラメータを記述したテンプレートであるcoherence-web.xml構成ファイルを生成します。使用可能なすべてのパラメータの詳細は、付録A「Coherence*Webコンテキスト・パラメータ」を参照してください。

    WebInstallerではサーブレット・コンテナを設定して、記憶域を無効化した状態で起動します(つまり、tangosol.coherence.session.localstoragefalseに設定します)。

    既存のcoherence-web.xml構成ファイルが存在する場合(たとえば、過去にCoherence*Web WebInstallerを実行したことがある場合)は、既存のファイルにあるコンテキスト・パラメータは生成したテンプレートにあるパラメータにマージされます。

  2. 目的のJava EEアプリケーションにある各WebアプリケーションからJSPを列挙して、各JSPに関する情報をcoherence-web.xml構成ファイルに追加します。

  3. 目的のJava EEアプリケーションにある各WebアプリケーションからTLDを列挙して、各TLDに関する情報をcoherence-web.xml構成ファイルに追加します。

インストールの手順では、Coherence*Web WebInstallerによって次のタスクが実行されます。

  1. アンインストールの手順で復元できるように、元のJava EEアプリケーションのバックアップを作成します。

  2. インスペクトの手順1で生成したCoherence*Web構成コンテキスト・パラメータを、目的のJava EEアプリケーションに含まれる各Webアプリケーションのweb.xmlディスクリプタ・ファイルに追加します。

  3. 各Webアプリケーションから、アプリケーション固有のServletContextListenerServletContextAttributeListenerServletRequestListenerServletRequestAttributeListenerHttpSessionListener、およびHttpSessionAttributeListenerの各クラス(TLDによって登録されたものを含む)を登録解除します。

  4. Coherence*Web ServletContextListenerクラスを各web.xmlディスクリプタ・ファイルに登録します。実行時に、Coherence*Web ServletContextListenerクラスによって、各アプリケーション固有のServletContextListenerリスナーに各ServletContextEventイベントが伝播します。

  5. Coherence*Web ServletContextAttributeListenerリスナーを各web.xmlディスクリプタ・ファイルに登録します。実行時に、Coherence*Web ServletContextAttributeListenerによって、各アプリケーション固有のServletContextAttributeListenerリスナーに各ServletContextAttributeEventイベントが伝播します。

  6. web.xmlディスクリプタ・ファイルで宣言した各アプリケーション固有のServletをCoherence*Web SessionServletでラップします。実行時に、各Coherence*Web SessionServletからラップされたServletに権限が委譲されます。

  7. インスペクト手順2で列挙した各JSPに次のディレクティブを追加します。

    <%@ page extends="com.tangosol.coherence.servlet.api22.JspServlet" %>
    

アンインストールの手順では、Coherence*Web WebInstallerによって、設定済のJava EEアプリケーションがインストール・プロセスの手順(1)で作成した元のバージョンのバックアップに置き換えられます。

4.5 Java EEセキュリティを使用しているアプリケーションへのCoherence*Webのインストール


注意:

Coherence*WebのネイティブなWebLogic Server SPI実装には、この項の内容は該当しません。これは、Java EEセキュリティを使用しているアプリケーションに、WebInstallerを使用してCoherence*Webをインストールする場合にのみ該当します。SPI実装を使用する手順は、第2章「WebLogic ServerでのCoherence*Webの使用方法」を参照してください。


Java EEセキュリティを使用しているアプリケーションにCoherence*Webをインストールするには、インストールで次の手順を別途実行してください。

  1. Coherence*WebセッションCookieを有効にします。

    詳細は、表A-1coherence-session-cookies-enabled構成要素を参照してください。

  2. Coherence*WebセッションCookieの名前を、目的のWebコンテナで使用していない名前に変更します。

    デフォルトでは、JSESSIONIDがほとんどのコンテナでセッションCookie名として使用されるため、Coherence*WebセッションCookie名としてはCSESSIONIDをお薦めします。詳細は、表A-1coherence-session-cookie-name構成要素を参照してください。

  3. 目的のWebコンテナに対するセッション・レプリケーションを有効にします。

    セッション・レプリケーションが有効になっていない場合、またはコンテナでセッション・レプリケーションの形態がサポートされていない場合は、フェイルオーバーの際にWebアプリケーションに対する再認証を実行する必要があります。セッション・レプリケーションの有効化に関する手順は、Webコンテナのドキュメントを参照してください。

この構成によって、指定の認証済ユーザーに次の2つのセッションが関連付けられます。

4.6 クロスサイト・スクリプティング攻撃の防止

coherence-session-cookie-httponlyコンテキスト・パラメータを使用して、HttpOnly属性をセッションCookieに追加します。HttpOnly属性は、CookieにJavaScriptなどのクライアント側のスクリプトがアクセスできないようにするため、クロスサイト・スクリプティングといった攻撃を防止するために使用します。すべてのブラウザがこの機能をサポートしているわけではありません。このコンテキスト・パラメータは、設定済アプリケーションの場合のみ使用可能です。