Oracle® Fusion Middleware Oracle WebLogic ServerにおけるWebサーバー1.1プラグインの使用 11g リリース1 (11.1.1) B61009-08 |
|
![]() 前 |
![]() 次 |
この章では、Oracle iPlanet Web Serverプラグインをインストールして構成する方法を説明します。以前のリリースでは、このプラグインはNetscape Enterprise Serverプラグインと呼ばれていました。
この章には次の項が含まれます:
Oracle iPlanet Web Server用プラグインでは、リクエストをOracle iPlanet Web ServerからOracle WebLogic Serverへプロキシできます。このプラグインによって、WebLogic Serverの動的な機能を必要とするリクエストをWebLogic Serverで処理できるようにすることで、Oracle iPlanet Web Serverのインストールが拡張されます。
Oracle iPlanet Web Serverプラグインは、静的ページがOracle iPlanet Web Serverによって提供され、JSPや、HTTPサーブレットで生成されたページなどの動的ページの提供をOracle WebLogic Serverのインスタンス(別のプロセスで、場合によっては別のマシン上で動作)が委任される環境用に設計されています。WebLogic ServerとOracle iPlanet Web Serverプラグインは、クリア・テキストまたはSecure Sockets Layer (SSL)を使用して接続されます。エンド・ユーザーには(つまり、ブラウザでは)、WebLogic Serverへ委任されるHTTPリクエストは、静的ページと同じソースに由来しているように見えます。また、WebLogic ServerのHTTPトンネリング機能もOracle iPlanet Web Serverプラグインを介して動作すると、動的ページのみでなく、すべてのWebLogic Serverサービスへのアクセスを提供できます。
Oracle iPlanet Web Serverプラグイン12.1.3は、Oracle iPlanet Web Server内のモジュールとして機能します。モジュールは起動時にロードされ、その後、構成に基づいて特定のHTTPリクエストがモジュールへ委任されます。
Oracle iPlanet Web Serverの詳細は、http://download.oracle.com/docs/cd/E18958_01/doc.70/e18789/chapter.htm
を参照してください。
次の各項では、Oracle iPlanet Web Serverプラグインのインストール前提条件および構成方法について説明します。
Oracle iPlanet Web Serverプラグインをインストールする前に、次のことを行ってください。
プラグインのzipを解凍する場所(PLUGIN_HOME(たとえば、/home/myhome/weblogic-plugins-1.1/))を作成します。
第1.2項「バージョン1.1プラグインの入手方法」の説明に従って、Oracle iPlanet Web Serverプラグインをダウンロードします。
プラグインのzipディストリビューションをWebサーバーのインストール・ディレクトリ(install-dir)に解凍します。プラグインのzipディストリビューションを解凍する前に、install-dir内の既存のREADME.txtの名前を変更してください。このディストリビューションには、次のようなファイルが含まれています。
SSLを使用する場合は、JDK 7をインストールします。orapki
ユーティリティを使用する場合は、JDK 7のインストールが必要です。orapki
ユーティリティでは、SSLで使用するための、ウォレットや証明書失効リストなどの公開鍵インフラストラクチャ(PKI)要素を管理します。
IPLANET_HOMEにインストールされたサポート済Oracle iPlanet Web Serverインストール環境(7.0.9以降)を作成しました。つまり、iplanet-host:iplanet-portをリスニングするiPlanetサーバーです。
バージョン1.1プラグインは、http://www.oracle.com/technology/software/products/ias/files/fusion_certification.html
で説明されているOracle iPlanet Web Serverプラットフォーム上でサポートされます。
iPlanetインスタンスの場所(INSTANCE-DIR(たとえば、${IPLANET_HOME}/https-foo))を作成します。
サポートされているバージョンのWebLogic Serverを構成し、ターゲット・システム上で実行します。このサーバーは、プラグインのzipディストリビューションを解凍したシステム上で実行する必要はないことに注意してください。WebLogic Serverのサポートされているバージョンについては、次のサイトを参照してください。
http://www.oracle.com/technology/software/products/ias/files/fusion_certification.html
Oracle iPlanet Web Serverプラグインは、UNIXプラットフォームでは共有オブジェクト(.so
)として、WindowsではDLL(.dll)として配布されます。
Oracle iPlanet Web Serverに、モジュールとしてネイティブ・ライブラリ(UNIXまたはWindows)をロードするよう指示するには、magnus.conf
ファイルに次の行を追加します。
Init fn="load-modules" shlib="mod_wl.so"
magnus.conf
ファイルはINSTANCE-DIR/config
ディレクトリにあります。ここでのINSTANCE-DIR
は、Webサーバー・インスタンスのディレクトリです。詳細は、次の章を参照してください。
http://download.oracle.com/docs/cd/E19146-01/821-1827/821-1827.pdf
この項では、Oracle iPlanet Web Serverプラグインの構成について説明します。
obj.conf
ファイルを見つけて開きます。
デフォルトのobj.conf
ファイルは、INSTANCE-DIR/config
ディレクトリにあります。ここでのINSTANCE-DIR
は、Webサーバー・インスタンスのディレクトリです。
詳細は、次を参照してください。
http://download.oracle.com/docs/cd/E19146-01/821-1827/821-1827.pdf
obj.conf
ファイルを構成する方法は複数あります。
第3.2.5項「obj.confファイルの変更のガイドライン」を参照してください。obj.conf
ファイルでは、WebLogic Serverにプロキシされるリクエストや他の構成情報を定義します。
URLによりリクエストをプロキシする(「パスによるプロキシ」とも呼ぶ)には、プロキシするURLごとに別個の<Object>
タグを作成し、PathTrim
パラメータを定義します。文字列*/weblogic/*
を含むリクエストをプロキシする、<Object>
タグの例を次に示します。
<Object ppath="*/weblogic/*"> Service fn=wl-proxy WebLogicHost=myserver.com WebLogicPort=7001 PathTrim="/weblogic" </Object>
WebLogic Serverの別々のインスタンスに送信されるリクエストを特定する、別個の2つのppath
のためのオブジェクト定義の例を次に示します。
<Object ppath="*/weblogic/*"> Service fn=wl-proxy WebLogicHost=myserver.com WebLogicPort=7001 PathTrim="/weblogic" </Object> <Object name="si" ppath="*/servletimages/*"> Service fn=wl-proxy WebLogicHost=otherserver.com WebLogicPort=7008 </Object>
注意: PathTrimなどの必須でないパラメータを使用すると、Oracle iPlanet Web Serverプラグインを介してppath を渡す方法を、より詳細に構成できます。プラグイン・パラメータの詳細なリストについては、第8.2項、第7.1項「Webサーバー・プラグインの一般パラメータ」を参照してください。 |
MIMEタイプによってリクエストをプロキシする場合は、obj.conf
ファイルで参照されているすべての新しいMIMEタイプを、mime.types
ファイルに追加します。MIMEタイプを追加するには、iPlanetサーバー・コンソールを使用するか、直接mime.types
ファイルを編集します。
直接mime.types
ファイルを編集する場合は、編集するファイルを開き、次の行を入力します。
type=text/jsp exts=jsp
iPlanet管理コンソールでmime.types
ファイルを編集する場合は、次を参照してください。
http://download.oracle.com/docs/cd/E19146-01/821-1828/gdabr/index.html
注意: iPlanet Web Server 7.0.9以降では、すでにJSP用のMIMEタイプが定義されています。既存のMIMEタイプをmagnus-internal/jspからtext/jspに変更してください。 |
指定したMIMEタイプの拡張子(.jspなど)を持つすべてのリクエストを、URLに関係なく、WebLogic Serverにプロキシできます。
たとえば、すべてのJSPをWebLogic Serverにプロキシするには、次のServiceディレクティブを追加してください。
Service method="(GET|HEAD|POST|PUT)" type=text/jsp fn=wl-proxy WebLogicHost=myserver.com WebLogicPort=7001 PathPrepend=/jspfiles
このServiceディレクティブによって、拡張子が.jspのすべてのファイルが、指定されたWebLogic Serverへプロキシされます。その際、ファイルは次のようなURLで提供されます。
http://myserver.com:7001/jspfiles/myfile.jsp
PathPrepend
パラメータの値は、リクエストのプロキシ先となるWebLogic ServerまたはクラスタにデプロイされているWebアプリケーションのコンテキスト・ルートと一致する必要があります。
Oracle iPlanet Web Serverプラグインのエントリを追加した後、デフォルトのObject定義は次の例のようになります。
<Object name="default"> AuthTrans fn="match-browser" browser="*MSIE*" ssl-unclean-shutdown="true" NameTrans fn="pfx2dir" from="/mc-icons" dir="/export/home/ws/lib/icons" name="es-internal" PathCheck fn="uri-clean" PathCheck fn="check-acl" acl="default" PathCheck fn="find-pathinfo" PathCheck fn="find-index" index-names="index.html,home.html ObjectType fn="type-by-extension" ObjectType fn="force-type" type="text/plain" Service method="(GET|HEAD|POST|PUT)" type="text/jsp" fn="wl-proxy" WebLogicHost="myweblogic.server.com" WebLogicPort="7100" Service method="(GET|HEAD)" type="magnus-internal/directory" fn="index-common" Service method="(GET|HEAD|POST)" type="*~magnus-internal/*" fn="send-file" Service method="TRACE" fn="service-trace" AddLog fn="flex-log" </Object>
WebLogic Serverにプロキシするその他すべてのMIMEタイプのデフォルトのオブジェクト定義に、同様のService文を追加できます。
MIMEによるプロキシが正しく機能するには、Oracle iPlanet Web ServerからのJavaを無効にする必要があります - 無効にしないと、SUN Oneが*.jsp
で終わるすべてのリクエストを処理しようとし、$doc_root
にリソースが見つからないため404エラーを戻すことになります。
Oracle iPlanet Web ServerでJavaを無効にするには、obj.conf
ファイルでname="default"
をコメント・アウトし、Webサーバーを再起動します。次のような設定も可能です。
の下にある #NameTrans fn="ntrans-j2ee" name="j2ee"
パスでプロキシする場合は、HTTPトンネリングを有効にします。
weblogic.jarを使用していてt3プロトコルをトンネリングする場合は、次のオブジェクト定義をobj.conf
ファイルに追加し、HTTPトンネリング・リクエストを処理させるWebLogic Serverホスト名とWebLogic Serverポート番号、またはWebLogicクラスタ名を置き換えてください。
<Object name="tunnel" ppath="*/HTTPClnt*" Service fn=wl-proxy WebLogicHost=myserver.com WebLogicPort=7001 </Object>
WebLogic Serverシン・クライアントwlclient.jarで使用される一意のプロトコルのIIOPをトンネリングする場合は、次のオブジェクト定義をobj.confファイルに追加し、HTTPトンネリング・リクエストを処理させるWebLogic Serverホスト名とWebLogic Serverポート番号、またはWebLogicクラスタ名を置き換えてください。
<Object name="tunnel" ppath="*/iiop*"> Service fn=wl-proxy WebLogicHost=myserver.com WebLogicPort=7001 </Object>
Oracle iPlanet Web Serverプラグインをテストするには:
WebLogic Serverを起動します。
Oracle iPlanet Web Serverを起動します。Oracle iPlanet Web Serverがすでに実行されている場合は、サーバーを再起動するか、再構成する必要があります。
Oracle iPlanet Web Serverプラグインをテストするには、次のURLを使用します。このサンプルで示すデフォルトのWebアプリケーションに対して定義されているとおりに、デフォルトのWebLogic Server HTMLページ、ウェルカム・ファイルまたはデフォルトのサーブレットが表示される必要があります。
http://webserver_host:webserver_port/weblogic/
デフォルトWebアプリケーションの作成方法の詳細は、『Oracle WebLogic Server Webアプリケーション、サーブレット、JSPの開発』を参照してください。
次の例では、バックエンドWebLogic Server(WLS)にリクエストをプロキシするようiPlanetプラグインを簡潔に設定するための基本的な手順を示します。
%IPLANET_INSTANCE_HOME%\config\magnus.confファイルを編集し、次を追加します。
... Init fn="load-modules" shlib="%PLUGIN_HOME%\lib\mod_wl.so" ...
%IPLANET_INSTANCE_HOME%\config\<vs-obj.conf>ファイル(デフォルトは%IPLANET_INSTANCE_HOME%\config\obj.conf)を開き、次のコードを追加します。
... <Object name="weblogic" ppath="*/wls/*"> Service fn="wl-proxy" WebLogicHost=<wls-host> WebLogicPort=<wls-port> Debug="ALL" WLLogFile="C:\Temp\wl-proxy.log" DebugConfigInfo="ON" PathTrim="/wls" </Object> ...
obj.confの内容の構成の詳細は、第3.2.6項「obj.confファイルのサンプル(WebLogicクラスタを使用しない場合)」および第3.2.7項「obj.confファイルのサンプル(WebLogicクラスタを使用する場合)」を参照してください。
プロンプトで、次のコマンドを入力してPATHに%PLUGIN_HOME%\libを追加します。
set PATH=C:\myhome\weblogic-plugin-1.1\lib:...
注意: libの内容をIPLANET_HOME\libにコピーするかIPLANET_INSTANCE_HOME\bin\startservを編集しても、PATHを更新できます。 |
プロンプトで、次のコマンドを入力してiPlanetサーバーを起動します。
%IPLANET_INSTANCE_HOME%\bin\startserv
ブラウザからhttp://iplanet-host:iplanet-port/mywebapp/my.jspにリクエストを送信し、レスポンスを確認します。
Oracle iPlanet Web Serverプラグインを使用するには、obj.conf
ファイルにいくつかの変更を加える必要があります。詳細は、次の章を参照してください。
http://download.oracle.com/docs/cd/E19146-01/821-1827/821-1827.pdf
クラスタを使用しない場合にobj.conf
ファイルに追加する必要がある行の例を次に示します。このサンプルをテンプレートとして使用し、ご使用の環境およびサーバーに合せて変更できます。#で始まる行はコメントです。
URLによるリクエストのプロキシ
## --------------BEGIN SAMPLE obj.conf CONFIGURATION--------- # (no cluster) # Configure which types of HTTP requests should be handled by the # iPlanet NSAPI plug-In (and, in turn, by WebLogic). This is done # with one or more "<Object>" tags as shown below. # Here we configure the iPlanet plug-In module to pass requests for # "/weblogic" to a WebLogic Server listening at port 7001 on # the host myweblogic.server.com. <Object ppath="*/weblogic/*"> Service fn=wl-proxy WebLogicHost=myweblogic.server.com WebLogicPort=7001 PathTrim="/weblogic" </Object> # Here we configure the plug-in so that requests that # match "/servletimages/" is handled by the # plug-in/WebLogic. <Object name="si" ppath="*/servletimages/*"> Service fn=wl-proxy WebLogicHost=myweblogic.server.com WebLogicPort=7001 </Object> ## -------------END SAMPLE obj.conf CONFIGURATION-------------------
MIMEタイプによるリクエストのプロキシ
This Object directive works by file extension rather than # request path. To use this configuration, you must modify the existing line or add the following line to mime.types file. ## -----------BEGIN SAMPLE mime.types CONFIGURATION--------------------- # # type=text/jsp exts=jsp ## ------------END SAMPLE mime.types CONFIGURATION---------------------- ## -------------BEGIN SAMPLE obj.conf CONFIGURATION--------------------- # This configuration means that any file with the extension # ".jsp" are proxied to WebLogic. Then you must add the # Service line for this extension to the Object "default", # which should already exist in your obj.conf file: <Object name=default> NameTrans fn=pfx2dir from=/ns-icons dir="c:/Export/Home/ns-icons" NameTrans fn=pfx2dir from=/mc-icons dir="c://Export/Home/ns-icons" NameTrans fn="pfx2dir" from="/help" dir="c:/Export/Home/manual/https/ug" NameTrans fn=document-root root="c:/Export/Home/docs" Service method="(GET|HEAD|POST|PUT)" type=text/jsp fn=wl_proxy WebLogicHost=myweblogic.server.com WebLogicPort=7001 PathPrepend=/jspfiles PathCheck fn=nt-uri-clean PathCheck fn="check-acl" acl="default" PathCheck fn=find-pathinfo PathCheck fn=find-index index-names="index.html,home.html" ObjectType fn=type-by-extension ObjectType fn=force-type type=text/plain Service method=(GET|HEAD) type=magnus-internal/imagemap fn=imagemap Service method=(GET|HEAD) type=magnus-internal/directory fn=index-common Service method=(GET|HEAD) type=*~magnus-internal/* fn=send-file AddLog fn=flex-log name="access" </Object> # The following directive enables HTTP-tunneling of the # WebLogic protocol through the iPlanet plug-in. <Object name="tunnel" ppath="*/HTTPClnt*"> Service fn=wl-proxy WebLogicHost=myweblogic.server.com WebLogicPort=7001 </Object> # ## -------------END SAMPLE obj.conf CONFIGURATION---------------------
WebLogic Serverクラスタを使用する場合にobj.conf
ファイルに追加する行の例を次に示します。このサンプルをテンプレートとして使用し、ご使用の環境およびサーバーに合せて変更できます。#で始まる行はコメントです。
URLによるリクエストのプロキシ
## -------------BEGIN SAMPLE obj.conf CONFIGURATION------------------- # (using a WebLogic Cluster) # # Configure which types of HTTP requests should be handled by the # iPlanet module (and, in turn, by WebLogic). This is done # with one or more "<Object>" tags as shown below. # Here we configure the iPlanet module to pass requests for # "/weblogic" to a cluster of WebLogic Servers. <Object ppath="*/weblogic/*"> Service fn=wl-proxy WebLogicCluster="myweblogic.com:7001,yourweblogic.com:7001, theirweblogic.com:7001" PathTrim="/weblogic" </Object> # Here we configure the plug-in so that requests that # match "/servletimages/" are handled by the # plug-in/WebLogic. <Object name="si" ppath="*/servletimages/*"> Service fn=wl-proxy WebLogicCluster="myweblogic.com:7001,yourweblogic.com:7001, theirweblogic.com:7001" </Object> ## ----------------END OF SAMPLE obj.conf CONFIGURATION------------------
MIMEタイプによるリクエストのプロキシ
# This Object directive works by file extension rather than # request path. To use this configuration, you must modify the existing line or add the following line to mime.types file.: ## -----------------BEGIN SAMPLE mime.types FILE ------------------------- # type=text/jsp exts=jsp # ## --------------------END SAMPLE mime.types------------------------------ ## -------------BEGIN SAMPLE obj.conf CONFIGURATION----------------------- # This configuration means that any file with the extension # ".jsp" is proxied to WebLogic. Then you must add the # Service line for this extension to the Object "default", # which should already exist in your obj.conf file: <Object name=default> NameTrans fn=pfx2dir from=/ns-icons dir="c:/Export/Home/ns-icons" NameTrans fn=pfx2dir from=/mc-icons dir="c:/Export/Home/ns-icons" NameTrans fn="pfx2dir" from="/help" dir="c://Export/Home/manual/https/ug" NameTrans fn=document-root root="c://Export/Home/docs" Service method="(GET|HEAD|POST|PUT)" type=text/jsp fn=wl_proxy WebLogicCluster="myweblogic.com:7001, yourweblogic.com:7001, theirweblogic.com:7001",PathPrepend=/jspfiles PathCheck fn=nt-uri-clean PathCheck fn="check-acl" acl="default" PathCheck fn=find-pathinfo PathCheck fn=find-index index-names="index.html,home.html" ObjectType fn=type-by-extension ObjectType fn=force-type type=text/plain Service method=(GET|HEAD) type=magnus-internal/imagemap fn=imagemap Service method=(GET|HEAD) type=magnus-internal/directory fn=index-common Service method=(GET|HEAD) type=*~magnus-internal/* fn=send-file AddLog fn=flex-log name="access" </Object> # The following directive enables HTTP-tunneling of the # WebLogic protocol through the NES plug-in. <Object name="tunnel" ppath="*/HTTPClnt*"> Service fn=wl-proxy WebLogicCluster="myweblogic.com:7001, yourweblogic.com:7001, theirweblogic.com:7001" </Object> # ## -------------END SAMPLE obj.conf CONFIGURATION--------------------