プロダクション業務ガイド

     前  次    目次     
ここから内容

伝播に関するトピック

この章では、WebLogic Portal 伝播に関連する様々なトピックについて説明します。ポータルの伝播を試みる前に、この章を読むことをお勧めします。

注意 : WebLogic Portal 8.1 または 9.2 で保存された WebLogic Portal インベントリは WebLogic Portal 10.0 伝播ツールでは使用できません。

この章では、以下のトピックについて説明します。

 


概要

図 6-1 は、伝播セッションの基本フローを示しています。伝播セッションの基本手順は次の通りです。

  1. 最初に、ソース システムと送り先システムからポータル インベントリをエクスポートします。
  2. インベントリをマージします。これらの伝播ツールにより、最終インベントリ ファイルを作成する前に、マージ済みインベントリ ファイルを表示および変更できます。
  3. 最終的なマージ済みインベントリを作成します。最終インベントリは、すべてのスコープ指定およびポリシ ルールが適用された後の 2 つのインベントリの結合を表します。スコープ指定については、「スコープについて」で説明されています。ポリシーについては、「ポリシーの使用」で説明されています。
  4. 最終インベントリ ファイルは、送り先サーバにアップロードされて、コミットされます。
  5. 図 6-1 伝播セッションのフロー


    伝播セッションのフロー

 


始める前に

以下の節では、ポータル アプリケーションを伝播する前に実行する準備タスクについて説明します。伝播計画プロセスの詳細については、「伝播方針の開発」を参照してください。

注意 : ソース システムと送り先のシステムが異なるデフォルトのロケールで JVM を実行する場合、両者の間で伝播を行うことは推奨していません。ロケールがソース システムと指定先システムで異なる場合は、パフォーマンスが低下し、すべてのポータル フレームワーク資産のローカライゼーションは変更マニフェストで常に異なって表示されます。

管理サーバの起動

伝播を実行して特定の LDAP データを更新できるようにするには、管理サーバが実行中である必要があります。伝播を実行すると、訪問者ロール、委託管理ロール、資格ポリシー、委託管理ポリシーなどの LDAP データが追加、削除、または更新される可能性があります。

データ バックアップの実行

WebLogic Server ドキュメントの「サーバ障害の回避とサーバ障害からの回復」の節の手順を使用して、WebLogic LDAP リポジトリをバックアップします。

ご使用の環境に対応したベンダ ツールを使用して、データベースをバックアップします。伝播するデプロイ済みアプリケーションのコピーを保存します。既存のアプリケーションに EAR をデプロイして現在のコンフィグレーションを上書きします。

インポート プロセス中にシステムを非アクティブ化するように計画

最終インベントリを送り先システムにインポートする前に、ユーザがポータル データを変更するのを防止する手順を実行します。最終インベントリが送り先サーバにコミットされているとき、WebLogic Portal Administration Console を通じて行われた変更は、データの紛失のように、望ましくない悪影響をもたらす可能性があります。

OnlineMaintenanceModeTask Ant タスクは、送り先サーバーに対する変更を防止するのに使用できます。WebLogic Portal Administration Console を使用して、サーバをメンテナンス モードにすることもできます。これを実行するには、[コンフィグレーション設定|サービス管理|メンテナンス モード] を選択します。OnlineMaintenanceModeTask の詳細については、「OnlineMaintenanceModeTask」を参照してください。Workshop for WebLogic は、メンテナンス モード機能を備えていません。

伝播ツールのインストール

Workshop for WebLogic 伝播機能は、WebLogic Portal のインストール時に (明示的に除外しない限り)、自動的にインストールされます。伝播 Ant タスクは、使用する前に、追加のコンフィグレーションが必要です。Ant タスクのインストールと使用に関しては、「伝播 Ant タスクの使用」を参照してください。

ログ ファイルのコンフィグレーション (オプション)

Workshop for WebLogic での詳細ログ ファイルのコンフィグレーションについては、「詳細ロギングの有効化」を参照してください。

J2EE アプリケーション (EAR) のデプロイ

Workshop for WebLogic を使用して、Web アプリケーションに対してポートレット、ポータル、ブック、ページ、カスタム レイアウト、ルック アンド フィール、メニュー、シェル、テーマ、JSP、Java クラスなどの新規リソースを作成した場合は、伝播ツールで変更をコミットする前に、ソース システムから送り先システムに J2EE アプリケーションをデプロイする必要があります。

ヒント : 送り先インベントリをエクスポートする前に、EAR ファイルをデプロイすることをお勧めします。これを実行することにより、最終インベントリを送り先にコミットした後、手動で実施しなければならない変更の数を減らすことができます。

J2EE アプリケーションをデプロイするときに、サーバがプロダクション モードと開発モードのどちらであるかに応じて、EAR ファイルに反映された変更が自動的に伝播されるかどうかが決まります。詳細については、「一般的な伝播のシナリオ」および「シナリオ 2 : EAR ファイルの再デプロイ」を参照してください。EAR ファイルのデプロイの詳細については、「ポータル アプリケーションのデプロイ」を参照してください。

J2EE アプリケーションをデプロイしないで伝播の変更をコミットした場合、インベントリ リストには新しいリソースは含まれますが、リソースは送り先システムのポータル ライブラリに表示されず、以下の送り先データベース テーブルが新しいデータで更新されません。

これらのデータベース テーブルの詳細と使用方法については、BEA WebLogic Portal のデータベース管理ガイドを参照してください。

必要な手動変更

伝播ツールはほとんどのポータル データを伝播しますが、いくつかの例外があります。伝播されないポータル資産は、WebLogic Portal Administration Console を使用して送り先サーバに追加する必要があります。

手動変更を必要とする種類のデータ

一般に、伝播ツールは次の種類のデータは伝播しません。

ヒント : 伝播および非伝播ポータル リソースの包括的リストについては、「伝播の参照表」を参照してください。

伝播されたデータが、伝播されないその他のデータに依存する場合があります。たとえば、委託管理ロールは送り先に伝播されますが、関連ユーザおよびグループは伝播されないため、これらの関連ユーザおよびグループを送り先システムに手動で追加する必要があります。

手動変更の報告先

手動変更は、次の場所で報告されます。

 


伝播の参照表

表 6-1 は、ポータルを構成するデータのカテゴリとタイプの包括的リストと、伝播ツールがそのデータを移動するかどうかを示しています。伝播ツールで伝播されないデータのタイプは、[メモ] の列に記載されています。伝播されないデータは、送り先サーバで手動変更が必要な場合があります。手動変更の詳細については、「必要な手動変更」を参照してください。

表 6-1 データ伝播の参照表
データ カテゴリ
データ
注意 :
フレームワーク
ポータル
 
デスクトップ
 
ブック
 
ページ
ページとそのレイアウト間の依存関係などのルック アンド フィール参照も伝播される。
ポートレット
 
ポートレット プリファレンス
 
ポートレット カテゴリ
 
 
コミュニティ テンプレート
 
フレームワーク (続き)
シェル
 
テーマ
 
メニュー
 
レイアウト
 
ルック アンド フィール
 
フレームワーク (続き)
ユーザのカスタマイズ
伝播されない。ユーザのカスタマイズは送り先システムで保持されるが、インポートされた変更が送り先に適用されると変更される可能性がある。詳細については、「ユーザ カスタマイズと伝播」を参照。
Datasync
カタログ プロパティ定義
 
コンテンツ セレクタ
 
割引定義
 
イベント定義
 
プレースホルダ
 
リクエスト プロパティ
 
セグメント
 
セッション プロパティ
 
ユーザ プロファイル定義
 
キャンペーン定義
 
実行時データ
行動追跡イベント
伝播されない。
順序
伝播されない。
ユーザ プロファイル
伝播されない。
セキュリティ
グローバル ロール (WebLogic Server を使用して作成)

注意 : パブリック資格 API を使って作成する定義は伝播されない。

訪問者資格ポリシー定義

注意 : 独自のカスタム コード (API) を使用して作成する定義は伝播されない。

委託管理ポリシー定義

注意 : 必要なロール (特定の資産が依存するロール) のみ伝播される。

次の委託管理ポリシーは伝播される。
  • ポータル リソース (ライブラリおよびデスクトップ レベル)
  • ユーザおよびグループ
  • コンテンツ セレクタ
  • キャンペーン
  • 訪問者ロール
  • プレースホルダ
  • セグメント
  • セキュリティ プロバイダ
委託管理ロールおよび訪問者資格ロール

注意 : 必要なロール (特定の資産が依存するロール) のみ伝播される。

注意 : 独自のカスタム コード (API) を使用して作成したロールは伝播されない。

注意 : ユーザとグループは伝播されないが、ユーザおよびグループ識別子は保持される。伝播されたロールに対応するユーザとグループを手動で作成する必要がある。

ユーザ
伝播されない。ハッシュされたパスワードは伝播できない。
グループ
伝播されない。
WSRP
WSRP 登録データ
リモート ポートレット
WSRP 伝播の詳細については、「連合ポータルの (WSRP) 伝播」を参照してください。
コンテンツ管理
すべてのコンテンツ管理情報、項目、タイプ、メタデータ、およびフォルダ
伝播はチェックアウト ステータスを移行しない (ステージングでチェックアウトされた項目がある場合、ユーザは伝播後に、プロダクションでそれをチェックアウトしない)。

注意 : ワークフローは伝播されない。

 


セキュリティ情報と伝播

セキュリティ情報は、一般に認証データと認可データから構成されます。表 6-2 に示すように、認可データはロールとポリシーから構成され、認証データはユーザとグループから構成されます。

表 6-2 セキュリティ データのタイプ
認可
ロール
  • 訪問者資格
  • 委託管理
  • グローバル (WebLogic Server で定義)
  • 委託ロール階層構造
内部プロバイダ、またはカスタム認可プロバイダなどの外部プロバイダに格納される。
 
ポリシー
  • 訪問者資格
  • 委託管理
 
認証
 
  • ユーザ
  • グループ
内部プロバイダ、または RDBMS ユーザ ストアや OpenLDAP などの外部プロバイダに格納される。プロバイダ コンフィグレーションと監査記録にも格納される。

ユーザとグループは伝播ツールで伝播されません。ユーザおよびグループ情報の他に、伝播ツールは次のものを伝播しません。

ロールにはユーザおよびグループ情報が含まれているため、ユーザおよびグループ情報をステージング システムとプロダクション システムに格納する方法を検討する必要があります。この 2 つのシステムは、同じ認証リポジトリを共有する場合と共有しない場合があります。

これらのシステムが、ユーザとグループを管理する認証リポジトリを共有しない場合は、ポータルを伝播した後で、各ロールを手動で編集して、適切なユーザおよびグループを送り先システムに追加する必要があります。システムが同じ認証リポジトリを共有する場合は、伝播後にロールに対して手動変更を行う必要はありません。

伝播の手動変更の詳細については、「必要な手動変更」を参照してください。

注意 : ベスト プラクティスは、ロール内の特定のユーザではなく、グループを参照することです。それによって、システムでユーザを追加または削除したときのロールの保守が簡単にできるようになります。

 


スコープについて

WebLogic Portal インベントリを、複数レベルの親ノートと子ノードによる、大きなツリー構造として考えることができます。ツリーの各ノードは、ポータル アプリケーションの一部に対するインベントリを表します。ノードがスコープに入るように宣言されると、そのノードとその下位ノードのすべてがスコープ内に入ります。すなわち、それらは、エクスポートされるインベントリ ファイルに含まれます。

この節では、次のトピックについて説明します。

概要

ポータル アプリケーション全体を伝播しない場合は、スコープを使用して、伝播される資産を限定することができます。スコープ指定の最も一般的な使用例には次のようなものがあります。

Workshop for WebLogic ベースの伝播ツールと伝播 Ant タスクの両方が、スコープ指定をサポートします。伝播ツールでは、マージ済みインベントリ ツリーでノードを選択または選択解除することにより、手動でスコープ指定を判断できます。Ant タスクでは、どのポータル項目がスコープ内にあるとみなされるかを指定する scope.properties ファイルにより、スコープ指定を管理できます。

ヒント : どのポータル アーティファクトが伝播に含まれるかを定義するのは、スコープであることを忘れないでください。デフォルトでは、スコープは、コンテンツ リポジトリ データを含むエンタープライズ アプリケーション全体に設定されます。手動またはプロパティ ファイルでスコープを指定するとき、何を含めるかを指定します。たとえば、1 つのデスクトップを指定した場合は、そのデスクトップとそのコンテンツ (ブック、ページなど) のみが伝播されます。ポータル内のそれ以外のデスクトップ、コンテンツ、および他の項目は伝播されません。スコープを 1 つのコンテンツ フォルダに限定した場合は、当該フォルダ、当該フォルダのコンテンツ、当該フォルダの親フォルダが伝播されますが、親フォルダのコンテンツは伝播されません。

スコープを使用する理由

パフォーマンスはスコープ指定の主要な理由です。スコープ指定インベントリは、エクスポートされる WebLogic Portal インベントリの全体のサイズを減らすので、伝播タスクは一般に高速で実行されます。大きなコンテンツ リポジトリがある場合、ポータル伝播時に、そのリポジトリをエクスポートしたくない場合があります。この場合、コンテンツ リポジトリとそのコンテンツすべてを、スコープ外に移動できます。

スコープ指定の別の理由は、セキュリティ関連です。インベントリを安全でないチャネルを通じて転送することを計画している場合、そのインベントリから特定の慎重を期するコンテンツを除外することができます。

スコープ指定のリスクとは

スコープの指定に関わる主要なリスクは、スコープ内に含まれるインベントリ ファイルに、解決不可能な依存関係がある資産が含まれる可能性があることです。インベントリがスコープ内に指定されると、ノード全体 (および当該ノードの派生ノード) がインベントリから除外されます。結果として、含まれているアーティファクトが除外されたアーティファクトに依存する場合、このような依存関係は解決不可能であり、伝播されたポータルが正常に機能しない場合があります。

ヒント : 特定のノードをインベントリから除外する場合、スコープ指定の代わりにポリシーを使用することを推奨します。ポリシーについては、「ポリシーの使用」で説明されています。

スコープ指定のベスト プラクティス

インベントリのスコープ指定を考える場合のベスト プラクティスは、次のとおりです。

スコープの設定方法

Workshop for WebLogic ベースの伝播ツールおよび Ant タスクで、伝播のスコープを設定できます。

この節では、次のトピックについて説明します。

Workshop for WebLogic を使用したスコープの設定

伝播ツールは 2 種類のスコープ指定を提供します。新しい伝播セッション ウィザードとマージ済みインベントリ ビューです。

ヒント : 伝播ツールの使用の詳細については、「Workshop for WebLogic 伝播ツールの使用」を参照してください。
新しい伝播セッション ウィザードでのグローバル スコープの設定

新しい伝播セッションを作成するとき、マージするソースおよび送り先インベントリを選択します。図 6-2 に示されているように、マージ前に、[グローバル スコープの選択] ダイアログで、スコープ設定の判断をする機会が与えられます。図に示されているように、スコープに入れるノードを選択するとき、そのノードの上位ノードが自動的に選択されます。

注意 : [グローバル スコープの選択] ダイアログで項目を選択するとき、スコープ内に含める項目を選択していることになります。エンタープライズ アプリケーション内のそれ以外のすべての項目は伝播のスコープ外になります。したがって、図 6-2 では、選択したシェル定義とその上位ノードのみが伝播されます。たとえば、コンテンツ項目の親フォルダは含まれますが、そのコンテンツ項目が依存するコンテンツ タイプは、自動的には含まれません。

[グローバル スコープの選択] ダイアログで選択するには、最初に [指定されたノードにスコープを限定] を選択する必要があります。

図 6-2 [グローバル スコープの選択] ダイアログ

[グローバル スコープの選択] ダイアログ

マージ済みインベントリ ビューでのスコープ設定

マージ済みインベントリ ビューでマージ済みインベントリのスコープを調整できます。このビューにより、最終インベントリ ファイルを生成する前に、マージ済みインベントリのスコープに最終変更を行うことができます。[グローバル スコープの選択] ダイアログとは違って、マージ済みインベントリ ビュー内の全ノードが選択されています。すなわち、デフォルトでは、それらすべてがスコープ内に入るとみなされます。図 6-3 では、Desktop_update_1 デスクトップが選択解除されています。これにより、そのデスクトップとその下位ノードが、伝播のスコープから除外されます。

図 6-3 マージ済みインベントリ ビューでのスコープ設定

マージ済みインベントリ ビューでのスコープ設定

Ant タスクによるスコープの設定

OnlineDownloadTask を使用して、インベントリ ファイルのスコープを設定できます。このタスクは、scope.properties ファイル属性を取得します。このファイルを編集して、インベントリ ファイルに含める項目が含まれるようにできます。scope.properties ファイルを指定しない場合、エンタープライズ アプリケーション全体がスコープ内にあるとみなされます。OnlineDownloadTask とその他の伝播 Ant タスクの詳細については、「伝播 Ant タスク リファレンス」を参照してください。

スコープ指定の影響

WebLogic Portal では、かなり自由にポータル インベントリのスコープを指定できます。インベントリ ノードをスコープ内またはスコープ外になるように選択するとき、その選択は通常、選択したノードに依存しているか、選択したノードの従属ノードであるその他のノードに影響します。WebLogic Portal は自動的にこれらの依存関係を判断します。Workshop for WebLogic では、視覚的に依存関係を見ることができます。ノードを選択すると、関連するその他のノードが自動的に選択されます。

この節では、次の 4 種類のスコープ指定の影響について説明します。

注意 : 開発モードでサーバに EAR ファイルをデプロイするとき、datasync データと一部のポータル フレームワーク データは自動的に抽出されて、データベースに配置されます。datasync データの一部またはすべてをスコープ指定によって除外する予定だった場合、そのデータは EAR デプロイメントにより自動的に追加され、事実上、スコープ指定が無効になることがわかります。

エンタープライズ アプリケーション レベルへのスコープ指定

デフォルトでは、すべての伝播は、エンタープライズ アプリケーション レベルにスコープ指定されます。これは、伝播可能なポータルを構成するすべてのアーティファクトが伝播されることを意味します。図 6-4 に示すように、デフォルトでは、エンタープライズ アプリケーション全体がスコープ内にあります。

図 6-4 エンタープライズ アプリケーション レベルでのスコープ指定

エンタープライズ アプリケーション レベルでのスコープ指定

事前に設定されたスコープ指定レベルはありません。伝播ツールと Ant タスクの両方で、必要に応じてスコープを指定できます。Ant タスクにより scope.properties ファイルを指定して、そこでどのアーティファクトを伝播するかを指定できます (「スコープ プロパティ ファイルについて」も参照)。

Workshop for WebLogic では、インベントリ ツリー内のノードを選択または選択解除することにより視覚的にスコープ指定します。選択したノードは、スコープ内にあるとみなされ、伝播されます。その他すべてのノードは伝播されません。

スコープ指定できる 4 つの主要なカテゴリのポータル アーティファクトがあります。

これらの最上位レベルの各ノードは、図 6-5 に示されているように、[新しい伝播セッション] ウィザードの [グローバル スコープの選択] ダイアログに表示されます。このダイアログを使用して、最上位レベルのカテゴリの 1 つを掘り下げて、スコープ指定のレベルを調整できます。ただし、前述のように、ベスト プラクティスは、コンテンツ サービスなどの最上位カテゴリの 1 つのみにスコープ指定することです。

図 6-5 [グローバル スコープの選択] ダイアログ

[グローバル スコープの選択] ダイアログ

デスクトップ レベルへのスコープ指定

最も一般的なスコープ指定使用例の 1 つは、デスクトップ レベルへのスコープ指定です。これは、1 つまたは複数の特定デスクトップがスコープ内に入るように指定することを意味します。残りのエンタープライズ アプリケーションは、スコープ外とみなされ、伝播されません。図 6-6 に示すように、Desktop_1 にスコープ指定すると、そのデスクトップとその子 (ブック、ページなど) は、スコープ内に配置されます。その他のデスクトップと残りのエンタープライズ アプリケーションは、スコープ外に配置されます。このレベルでのスコープ指定のリスクについては、「スコープ指定のリスクとは」を参照してください。

図 6-6 Desktop_1 へのスコープ指定

Desktop_1 へのスコープ指定

リポジトリへのスコープ指定

もう 1 つの一般的な使用例は、リポジトリへのスコープ指定です。リポジトリにスコープ指定すると、図 6-7 に示すように、すべてのタイプ、フォルダ、およびコンテンツを含むリポジトリ全体が伝播されます。その他のリポジトリは伝播されず、エンタープライズ アプリケーションのその他の部分も伝播されません。

図 6-7 リポジトリへのスコープ指定

リポジトリへのスコープ指定

コンテンツ フォルダへのスコープ指定

コンテンツ リポジトリ内のフォルダにスコープ指定する場合、そのフォルダ、そのコンテンツ、およびそのフォルダの親フォルダのすべてが伝播されます。図 6-8 に示すように、親フォルダのコンテンツは伝播されず、親フォルダ自体のみが伝播されることに注意してください。このレベルでのスコープ指定のリスクについては、「スコープ指定のリスクとは」を参照してください。

図 6-8 Content Folder_3 へのスコープ指定

Content Folder_3 へのスコープ指定

スコープとライブラリの継承

ページとブックを含むデスクトップなどのポータル資産を伝播するとき、新しいページとブックが既にポータル ライブラリに存在していない場合は、それらが追加されます。

WebLogic Portal Administration Console は、ライブラリ リソースとデスクトップ リソースから構成されるツリーにポータル リソースを編成します。ライブラリ リソースとデスクトップ リソース間の関係を理解すると、伝播の影響と結果を理解するのに役立ちます。

ポータル資産インスタンスと継承

次に、ポータル資産の次のインスタンス間の関係を説明します。

新しいデスクトップの作成とライブラリへの逆アセンブル

WebLogic Portal Administration Console を使用して新しいデスクトップを作成する場合は、既存のポータル テンプレートを使用できます。テンプレートの使用は、Workshop for WebLogic で作成された .portal ファイルからデスクトップのポータル リソースを直接取得することを意味します (.portal ファイルはプライマリ インスタンスとも呼ばれます)。デスクトップを作成すると、ポータル資産が .portal ファイルから削除され、データベースに配置されて、WebLogic Portal Administration Console のライブラリ ツリーとデスクトップ ツリーの両方に表示されます。新しいデスクトップ インスタンスから資産を取得し、それらをライブラリに配置することを逆アセンブルと呼びます。

この時点で、ライブラリ (ライブラリ インスタンス) 内の資産 (ブック、ページなど) は、対応するデスクトップ インスタンスの階層に関連しています。名前の変更など、ライブラリ リソースに対する変更は、対応するデスクトップ インスタンスに自動的に継承されます。一方、デスクトップ インスタンスに対する変更は、階層構造に反映されません。

注意 : 資産に対する変更が階層構造に「逆継承」されることはありません。デスクトップ資産に対する変更が、対応するライブラリ インスタンスに継承されることはありません。同様に、訪問者インスタンスに対する変更がデスクトップまたはライブラリ インスタンスに継承されることはありません。

デスクトップに作成した新しいブックとページは、逆アセンブルされません。これらはそのデスクトップに固有のものと見なされます。

プロパティ設定の分離

管理者または訪問者が (訪問者ツールを使用して) デスクトップ内のブックのブック プロパティまたはページのページ プロパティを変更した場合、これらのプロパティ設定は、ライブラリ内の親ブックまたはページの設定から分離されます。ページ プロパティにはレイアウトとテーマが含まれ、ブック プロパティにはメニューとレイアウトが含まれます。これらのプロパティは、WebLogic Portal Administration Console で変更できます。ポータルが伝播されると、ソース アプリケーション内で分離された資産は送り先でも分離されたままになります。

伝播される特定のデータの詳細については、「伝播の参照表」を参照してください。

 


ポリシーの使用

ポリシーを設定すると、ソース インベントリと送り先インベントリが最終的に 1 つのインベントリ ファイルにマージされる方法を管理できます。この節ではポリシーを説明し、ポリシーを適用する方法を理解するのに役立つ例を示します。

この節では、次のトピックについて説明します。

はじめに

ポリシーにより、次の 3 つのマージ例の処理方法を指定できます。

伝播ツールを通じて、次の 2 種類のポリシーを設定できます。

グローバル ポリシーの例

図 6-9 は、単純で一般的な例を示しています。この場合、デフォルトのグローバル ポリシーは 2 つのインベントリがマージされる方法を定義します。Desktop A 上の Portlet 2 と Portlet 3 は、送り先の Desktop A に追加されます。Desktop B からの Portlet 5 も追加されます。ただし、送り先の Portlet 6 は、ソース システムの Desktop B に存在していなかったので、削除されます。

ヒント : デフォルトでは、グローバル ポリシーが、追加、削除、および更新を受け入れるように設定されます。
図 6-9 追加と削除の受け入れ

追加と削除の受け入れ

図 6-10 は、同じソースおよび送り先システムを示していますが、この例では、グローバル ポリシーが追加を無視するように設定されています。この場合、Portlet 6 は、ソース デスクトップに存在していなかったので、送り先デスクトップから削除されます。グローバル ポリシーで、追加が無視されるように指定されているので、ソースからの追加のポートレットはどれも追加されません。

図 6-10 追加の無視と削除の受け入れ

追加の無視と削除の受け入れ

ローカル ポリシー オーバーライド

図 6-11 は、ローカル ポリシーがグローバル ポリシーをオーバーライドする方法を示しています。この例では、グローバル ポリシーは追加を受け入れますが、ローカル ポリシーが Desktop A の Portlet 1 に配置されています。ローカル ポリシーは、ポートレットを送り先から削除するように指定します。この場合、Desktop A の Portlet 1 は伝播されません。ローカル ポリシーがグローバル ポリシーをオーバーライドします。

図 6-11 ローカル ポリシーによるグローバル ポリシーのオーバーライド

ローカル ポリシーによるグローバル ポリシーのオーバーライド

ローカル ポリシーのデスクトップでの使用

WebLogic Portal で、複数のデスクトップに、ポートレットなどの同じライブラリ オブジェウトのインスタンスを含めることができます。

ヒント : ポートレットのように、アーティファクトのライブラリ インスタンスとデスクトップ インスタンス間の違いを理解することが重要です。この違いの詳細については、「スコープとライブラリの継承」および「エクスポートとインポートのスコープ」を参照してください。

グローバル ポリシーはデスクトップ レベルでオーバーライドされる可能性があるので、(ポートレットなどの) 同じライブラリ オブジェクトのインスタンスに対するポリシーが衝突する可能性があります。伝播ソフトウェアはこのような衝突を次のように解決します。

たとえば、次のシナリオを検討します。ユーザが Page 1 をソース システムの Book 2 に追加しますが、別のユーザが同じ Page 1 を送り先システムの Book 3 に追加します。ソースへの追加は送り先に追加され、ソースでの「削除」は無視されるというルールが定義されています (つまり、ある資産が送り先にあり、ソースにはない場合、その資産は送り先に残ります)。WebLogic Portal では、ある特定のページが複数のブックに存在できないため、伝播ツールは Page 1 を Book 2 に追加し、送り先システムの Book 3 から Page 1 を削除することで衝突を解決します。

もう 1 つの例として、次のシナリオを検討します。

このシナリオでは、図 6-12 に示すように、Desktop A に対するローカル ポリシーと Desktop B により継承されるグローバル ポリシー間で、追加に関して衝突があります。Desktop B は、Portlet X を含んでいるので、Portlet X は Desktop B の伝播に必要です (Desktop B は、このポートレットなしでは正確に伝播できません)。したがって、前述のルールに従って、Desktop A に適用されるポリシー オーバーライドが、追加を無視することを示すにもかかわらず、Portlet X に対するライブラリ オブジェクトが伝播に含まれます。

図 6-12 ローカル ポリシーとライブラリ インスタンス

ローカル ポリシーとライブラリ インスタンス

ポリシーに基づく変更の報告

伝播の衝突が伝播 Ant タスクにより解決されるとき、解決は処理中に作成されるログ ファイルに一覧表示されます。Workshop for WebLogic ベースのインタフェースは、コンソール ビューに、衝突を解決するために発生した変更を一覧表示します。

ログ ファイルの詳細については、「ログ ファイルの確認」を参照してください。

 


マージ済みインベントリの変更のプレビューと調整

基本的な伝播プロセスは、ソース インベントリと送り先インベントリで開始します。次のこれらの 2 つのファイルを、Workshop for WebLogic または伝播 Ant タスクのいずれかを使って、マージ済みインベントリ ファイルにマージします。

最終インベントリ ファイルを生成してコミットする前に、送り先サーバで行われる予定の保留中の変更を検討する機会があります。次のようにして、これらの変更を表示できます。

 


ユーザ カスタマイズと伝播

通常の伝播は、ステージング環境からプロダクション システムに対して行われます。このシナリオでは、ユーザは一般にステージング環境に対するアクセス権を持たず、伝播を必要とするユーザ カスタマイズ変更はありません。このため、ユーザ カスタマイズは伝播されません。

一般に、ステージング システムに対する変更をプロダクション システムに伝播する場合、ステージングされた変更とユーザ カスタマイズの移行は、ステージングされた変更が Administration Console を使用してプロダクション システムに対して直接行われた場合と同じように行われます。

ユーザ カスタマイズは送り先システムで保持されますが、送り先システムに伝播すると、これらのカスタマイズは一定の状況で送り先サーバ上で削除または変更されることがあります。たとえば、管理者が WebLogic Portal Administration Console を通じて、特定のユーザのカスタマイズと衝突する可能性のある変更を行うことがあります。ユーザが訪問者ツールを使用してページの 1 つに追加した特定のポートレットを、管理者がポータルから削除したとします。この場合、そのポートレットは存在しなくなり、次のログイン時にユーザのポータルに表示されません。つまり、ユーザのカスタマイズは「失われます」。

 


ログ ファイルの確認

ヒント : 伝播を行なうたびに詳細ログを確認してすべての伝播選択が処理されたか確かめ、サーバ ログを確認して伝播エラーをチェックすることをお薦めします。

伝播業務とタスクは、次の場所にログ メッセージを生成します。

 


インポート プロセスのロールバック

伝播ツールはトランザクション対応ではないので、ロールバック機能はサポートしていません。伝播前の環境に戻す必要がある場合は、伝播プロセスを開始する前に作成したバックアップを使用します。詳細については、「データ バックアップの実行」を参照してください。

 


連合ポータルの (WSRP) 伝播

この節では、連合ポータルの伝播について説明します。

ヒント : WebLogic ポータル 10.0 にアップグレードする場合、この節を読む前に『WebLogic Portal へのアップグレード ガイド』の連合ポータルのアップグレードに関する節を読むことをお進めします。『WebLogic Portal 10.0 へのアップグレード』では、連合ポータルを WebLogic Portal 8.1 から 10.0、および 9.2 から 10.0 にアップグレードする方法について説明します。

この節では、次のトピックについて説明します。

はじめに

WebLogic Portal 10.0 は WSRP 2.0 の機能をサポートし、より柔軟で実践的な連合ポータルの伝播アプローチを可能にします。WebLogic Portal 10.0 では、ステージングおよびプロダクション環境のコンシューマ アプリケーションが個別のプロデューサをポイントすることが可能です。この新機能の主な利点は、プロダクション環境とは独立して、ステージング環境でリモート (プロキシ) ポートレットを作成および変更できる点です。

バージョン 10.0 より前は、WSRP コンシューマ アプリケーションを伝播する場合、ソース システムと送り先システムに存在するコンシューマに同じプロデューサを指定する必要がありました。このコンフィグレーションには制限事項がいくつか含まれており、詳細は『WebLogic Portal 9.2 のプロダクション業務ガイド』の「伝播に関するトピック」で説明しています。WebLogic Portal での WSRP の使用については、『連合ポータル ガイド』を参照してください。

WSRP 伝播手順

プロデューサとコンシューマ の両アプリケーションが WebLogic Portal 10.0 (新規インストールまたはアップグレード) にある場合は、コンジューマの伝播は完全にサポートされます。ステージング コンシューマとプロダクション コンシューマが同じプロデューサを指定する必要はありません。この推奨コンフィグレーションは、図 6-13 に示します。WebLogic Portal 10.0 への連合ポータルのアップグレードの詳細については、『WebLogic Portal アップグレード ガイド』を参照してください。

図 6-13 独立したプロデューサを指定するコンシューマ (推奨コンフィグレーション)

独立したプロデューサを指定するコンシューマ (推奨コンフィグレーション)

ロデューサ アプリケーションとコンシューマ アプリケーションの両方を WebLogic Portal 10.0 にアップグレードした場合の連合ポータルの伝播の手順を以下に説明します。

注意 : 次の手順は、プロデューサがそれ自体を登録するコンシューマを必要としたかどうかにかかわらず、適用されます。
  1. 伝播する前に、プロデューサを送り先のシステムのコンシューマ アプリケーションに追加します。プロデューサの追加については、WebLogic Portal Administration Console のオンライン ヘルプを参照してください。プロデューサが登録を必要とする場合は、必要な登録手順を実行しなければなりません。選択するプロデューサ ハンドルは、ソース システムでプロデューサを登録するために使用したハンドルと一致しなければなりません
  2. たとえば、プロデューサをプロデューサ ハンドル myProducer を持ったステージングのコンシューマに追加または登録した場合は、myProducer をプロダクション領域のプロデューサ ハンドルとしても使用しなければなりません。

    注意 : 手順 1 はポータルを初めて伝播するときにのみ実行する必要があります。
  3. プロデューサの伝播。ステージング環境にあるいずれかのプロデューサにデプロイされた新しいポートレットはすべて、そのポートレットがコンシューマにアクセスされる場合、送り先システムへ伝播する必要があります。
  4. 注意 : プロデューサ上でポートレット定義に変更を加えた場合、手順 2 を実行する必要があります。
  5. ソース システムから送り先システムへコンシューマ ポータル アプリケーションを伝播します。

伝播が完了すると、プロダクション環境のコンシューマ ポータルはステージング環境のコンシューマ ポータルと機能的に同等になります。

注意 : すべてのプロデューサとコンシューマを WebLogic Portal 10.0 にアップグレードしない場合、コンシューマがそれぞれ別のプロデューサを指定するコンフィグレーション (図 6-13) はサポートされません。WebLogic Portal 10.0 への連合ポータルのアップグレードの詳細については、『WebLogic Portal アップグレード ガイド』を参照してください。

プロデューサのみ WebLogic Portal 10.0 にアップグレードする場合

プロデューサを WebLogic Portal 10.0 にアップグレードしてもコンシューマはアップグレードしない場合、必ず以下の手順に従ってください。

  1. 各コンシューマ アプリケーションからプロデューサ登録ハンドルを取得します。これを行うには、リスト プロデューサの JSP ユーティリティを プロデューサ ハンドルのリスト化 の説明に従って実行します。
  2. アップグレードされた各プロデューサ アプリケーションのプロデューサ登録ハンドルを更新します。これを行うには、更新登録の JSP ユーティリティを プロデューサ登録ハンドルの更新 の説明に従って実行します。
  3. コンシューマ アプリケーションを伝播します。

コンシューマのみ WebLogic Portal 10.0 にアップグレードする場合

コンシューマのみ 10.0 にアップグレードする場合、『WebLogic Portal 9.2 プロダクション業務ガイド』の「伝播に関するトピック」で説明された伝播モデルを使用する必要があります。このモデルでは、ステージングとプロダクションの両方の環境のコンシューマ アプリケーションが同じプロデューサをポイントする必要があります。

プロデューサ ハンドルのリスト化

注意 : この節で説明するユーティリティを実行する必要があるのは、コンシューマ アプリケーションがデプロイされたシステム上のみです。

この節では、コンシューマ アプリケーションがデプロイされているステージングおよびプロダクションの両方のシステムでプロデューサ リスト JSP ユーティリティ (listProducers.jsp) を実行する方法について説明します。このユーティリティは、コンシューマに事前に追加されているプロデューサの登録ハンドルを取得します。

注意 : JSP の実行には管理者権限が必要です。
注意 : コンシューマ アプリケーションが WebLogic Portal 9.2 または 8.1.5 (およびこれ以降) の環境にデプロイされる場合、以下の手順 1 と 2 を実行する必要があります。コンシューマ環境がすでに WebLogic Portal 10.0 にアップグレードされている場合は、手順 1 と 2 は必要ありません。
  1. この手順は、コンシューマ アプリケーションが WebLogic Portal 9.2 または 8.1.5 (およびこれ以降) の環境にデプロイされた場合のみ必要になります。以下の J2EE 共有ライブラリから listProducers.jsp ファイルを展開します。WinZip などのアーカイブ ツールを使用して、listProducers.jsp ファイルをアーカイブから展開できます。
  2. WEBLOGIC_HOME/portal/lib/modules/wlp-propagation-web-lib.war

  3. この手順は、コンシューマ アプリケーションが WebLogic Portal 9.2 または 8.1.5 (およびこれ以降) の環境にデプロイされた場合のみ必要になります。展開した listProducers.jsp ファイルを、コンシューマがデプロイされている Web アプリケーションにコピーします。これを、ステージングとプロダクションの両方のシステムで行います。
  4. ステージング システム、またはソース システム上でリスト プロデューサ の JSP ユーティリティを実行します。10.0 をインストールするために、ブラウザを開いて以下の URL を入力します。
  5. http://host:port/EarProjectNamePropagation/wsrp/listProducers.jsp

    EarProjectName はサーバにデプロイされたエンタープライズ アプリケーションの名前です。次に例を示します。

    http://localhost:7001/myEarPropagation/wsrp/listProducers.jsp

    9.2 または 8.1.5 (およびそれ以降) のインストールでは、URL は JSP の配置場所に依存しています。次に例を示します。

    http://host:port/EarProjectNamePropagation/mydir/listProducers.jsp

  6. メッセージが表示されたら、サーバの正しいユーザ名とパスワードを入力します。
  7. リスト プロデューサ JSP では、ソース システムでコンシューマ Web アプリケーションの名前を選択します。
  8. [Submit Query] をクリックします。JSP は、コンシューマに追加された各プロデューサのプロデューサ ハンドル、WSDL、および登録ハンドルを含む表を返します。
  9. この表にある情報を印刷またはコピーします。次の節、プロデューサ登録ハンドルの更新で手順を完了する際にこの情報が必要になります。
  10. プロダクション システムと送り先システムでこの手順を繰り返します。

プロデューサ登録ハンドルの更新

注意 : この節で説明するユーティリティを実行する必要があるのは、プロデューサ アプリケーションがデプロイされたシステム上のみです。

この節では、ステージング システムとプロダクション システムの両方で更新登録の JSP ユーティリティ (updateRegistrations.jsp) を実行する方法を説明します。このユーティリティは、指定のプロデューサを現在参照している各コンシューマ アプリケーションの登録ハンドルを更新します。

注意 : プロデューサ アプリケーションが WebLogic Portal 9.2 または 8.1.5 (およびこれ以降) の環境にデプロイされる場合、以下の手順 1 と 2 を実行する必要があります。プロデューサ環境がすでに WebLogic Portal 10.0 にアップグレードされている場合は、手順 1 と 2 は必要ありません。
  1. この手順は、プロデューサ アプリケーションが WebLogic 9.2 または 8.1.5 (およびこれ以降) の環境にデプロイされた場合のみ必要になります。以下の J2EE 共有ライブラリから updateRegistrations.jsp ファイルを展開します。WinZip などのアーカイブ ツールを使用して、updateRegistrations.jsp ファイルをアーカイブから展開できます。
  2. WEBLOGIC_HOME/portal/lib/modules/wlp-propagation-web-lib.war

  3. この手順は、プロデューサ アプリケーションが WebLogic 9.2 または 8.1.5 (およびこれ以降) の環境にデプロイされた場合のみ必要になります。展開した updateRegistrations.jsp ファイルを、プロデューサがデプロイされている Web アプリケーションにコピーします。これを、ステージングとプロダクションの両方のシステムで行います。
  4. 送り先システムで、更新登録 JSP を実行します。そのためには、ブラウザを開いて、次の URL を入力します。
  5. http://host:port/EarProjectNamePropagation/wsrp/updateRegistrations.jsp

    EarProjectName はサーバにデプロイされたエンタープライズ アプリケーションの名前です。次に例を示します。

    http://localhost:7001/myEarPropagation/wsrp/updateRegistrations.jsp

  6. メッセージが表示されたら、サーバの正しいユーザ名とパスワードを入力します。
  7. JSP では、プロデューサ ハンドルのリスト化 ですでに説明したリスト プロデューサ ユーティリティを実行して、コンシューマ アプリケーションから取得されたソースおよび対応する送り先登録ハンドルを入力します。
  8. [送信] をクリックします。
  9. プロデューサで登録された伝播に含まれる各コンシューマにこの手順を繰り返します。
注意 : どちらのコンシューマもリモート ポートレットへアクセスできるよう、更新登録 JSP で登録がコピーされます。

 


デフォルトのアップロード ファイル サイズの増加

伝播管理サーブレットのコンフィグレーション設定により、Dos 攻撃を軽減することができます。サーブレットは、アップロード ファイル (HTTP 経由でアップロードされるファイル) に許可される最大サイズでコンフィグレーションされます。デフォルトでは、1MB に設定されます。インベントリ ZIP ファイル内でこの値を超えたファイルは拒否されます。この節では、この制限を回避する方法、または伝播サーブレットのコンフィグレーションを変更してより大きなファイルを許可するように変更する方法を説明します。

インベントリのサーバへのコピー

このファイル サイズ制限を回避する最も簡単な方法は、物理的にファイルを FTP またはその他の手段を使って、ソースから送り先サーバにコピーすることです。ファイルを送り先にコピーした後、OnlineUploadTask の readFromServerFileSystem 属性を使用して、アップロードを実行できます。このタスクの詳細については、「OnlineUploadTask」を参照してください。

デプロイメント計画の変更

デプロイメント計画を使って、1MB のデフォルトのファイル アップロード制限をオーバーライドできます。デプロイメント計画は、WebLogic Server へのデプロイメントのためのアプリケーションをコンフィグレーションするオプションの XML ファイルです。デプロイメント計画を使用するには、通常は WebLogic Server デプロイメント記述子に定義されるプロパティ値を設定するか、または WebLogic Server デプロイメント記述子に定義済みのコンテキスト パラメータ値をオーバーライドします。

ヒント : デプロイメント計画の作成と使用については、WebLogic Server ドキュメントに詳しく記載されています。詳細については、「プロダクション デプロイメントのためのアプリケーションのコンフィグレーション」および「プロダクション環境でのアプリケーションの更新」を参照してください。

デプロイメント計画を使ってファイル サイズ制限を変更するには、次の手順に従います。

  1. デプロイメント計画ファイルを作成します。WebLogic Server ドキュメントで説明されているように、デプロイメント計画を作成するにはいくつかの方法があります。コード リスト 6-1 は、伝播 Web アプリケーションを変更するようにコンフィグレーションされるサンプルのデプロイメント計画を示しています。
  2. ヒント : デプロイメント計画の場所は、ドメインの config.xml ファイルで指定する必要があります。コード リスト 6-2 は、サンプル スタンザを示しています。詳細については、WebLogic Server ドキュメントを参照してください。
  3. <variable-definition><variable-assignment> 要素を追加して、コンテンツ デプロイメント記述子の parameter maximum_inventoryfile_upload_size を変更します。これらの要素は、コード リスト 6-1 で太字で強調表示されています。例では、アップロード ファイル サイズ制限が 3MB に変更されています。オーバーライドされた記述子が、アプリケーションの web.xml ファイルに関連付けられています。
  4. コード リスト 6-1 サンプルのデプロイメント計画
    <deployment-plan xmlns="http://www.bea.com/ns/weblogic/90" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <application-name>drtApp</application-name>
    <variable-definition>
    <variable>
    <name>CHANGEUPLOAD</name>
    <value>3000000</value>
    </variable>
      </variable-definition>

    <module-override>
    <module-name>propagation.war</module-name>
    <module-type>war</module-type>
    <module-descriptor external="false">
    <root-element>weblogic-web-app</root-element>
    <uri>WEB-INF/weblogic.xml</uri>
    </module-descriptor>
    <module-descriptor external="false">
    <root-element>web-app</root-element>
    <uri>WEB-INF/web.xml</uri>
    <variable-assignment>
             <name>CHANGEUPLOAD</name>
    <xpath>/web-app/context-param/
            [param-name="maximum_inventoryfile_upload_size"]/param-value</xpath>
    </variable-assignment>

    </module-descriptor>
    </module-override>
    </deployment-plan>
    コード リスト 6-2 サンプル config.xml でのデプロイメント計画の場所
    <app-deployment>
    <name>drtApp</name>
    <target>portalServer</target>
    <module-type>ear</module-type>
    <source-path>/myProject/myApplication</source-path>
    <deployment-order>101</deployment-order>
    <plan-dir>/myProject/applications/plan</plan-dir>
         <plan-path>plan.xml</plan-path>
    <security-dd-model>Advanced</security-dd-model>
    </app-deployment>
  5. WebLogic Server ドキュメントの「プロダクション環境でのアプリケーションの更新」で説明されているように、アプリケーションを再デプロイします。

web.xml ファイルの変更

注意 : この方法は推奨されていません。

伝播アプリケーションの web.xml ファイルで直接ファイルのアップロード サイズをコンフィグレーションできます。このファイルを変更するには、次の手順に従います。

  1. 伝播アプリケーションの WAR ファイルを配置します。このファイルは次の場所にあります。
  2. WEBLOGIC_HOME/portal/lib/modules/wlp-propagation-web-lib.war
  3. WAR ファイルをアンパックし、編集用に web.xml ファイルを開きます。
  4. コード リスト 6-3 に示すように、web.xml ファイルにスタンザを追加します。この例では、デフォルトのファイル サイズが 3MB に変更されています。
  5. コード リスト 6-3 デフォルトのアップロード サイズの変更
    <context-param>
        <description>Maximum upload size (in bytes), if not specified
            defaults to 1 MB.
        </description>
        <param-name>maximum_inventoryfile_upload_size</param-name>
        <param-value>3000000</param-value>
    </context-param>
  6. WAR ファイルを再パッケージします。
  7. アプリケーションを再デプロイします。

 


伝播サーブレットのコンフィグレーション

伝播サーブレットに影響するいくつかのコンフィグレーション パラメータは、伝播 Web アプリケーションの web.xml ファイルで指定されます。これらのパラメータの変更方法としては、デプロイメント計画の使用を推奨します。

デプロイメント計画は、WebLogic Server へのデプロイメントのためのアプリケーションをコンフィグレーションするオプションの XML ファイルです。デプロイメント計画を使用するには、通常は WebLogic Server デプロイメント記述子に定義されるプロパティ値を設定するか、または WebLogic Server デプロイメント記述子に定義済みのコンテキスト パラメータ値をオーバーライドします。

ヒント : デプロイメント計画の作成と使用については、WebLogic Server ドキュメントに詳しく記載されています。詳細については、「プロダクション デプロイメントのためのアプリケーションのコンフィグレーション」および「プロダクション環境でのアプリケーションの更新」を参照してください。
ヒント : デプロイメント計画を使用した伝播サーブレットのコンフィグレーションの詳細については、「デフォルトのアップロード ファイル サイズの増加」の節を参照してください。

次の節で、伝播アプリケーションの web.xml ファイルに対するコンテキスト パラメータを示します。これらのパラメータをオーバーライドするには、デプロイメント計画を使用します。パラメータは次のコンフィグレーションを設定するのに使用されます。

インベントリのエクスポート ディレクトリ

コード リスト 6-4 に表示されるスタンザ例は、エクスポートされるインベントリ ZIP ファイルを配置する一時ディレクトリを指定するのに使用されます。

コード リスト 6-4 インベントリのエクスポート ディレクトリ
context-param>
    <description>Base folder path for runtime data, such as
        inventory exports.
    </description>
    <param-name>inventoryWorkingFolder</param-name>
    <param-value>D:\dev\src\wlp\propagation\test\inventories</param-value>
</context-param>

説明テキスト

コード リスト 6-5 に表示されるスタンザ例は、export.properties ファイルに配置される短い説明を指定するのに使用されます。このファイルには、エクスポートを行うユーザ、エクスポート日時、エクスポートに含まれるノード数などのインベントリの概要情報が格納されています。

コード リスト 6-5 説明テキスト
<context-param>
    <description>The name of the operating environment.</description>
    <param-name>environment_name</param-name>
    <param-value>Staging</param-value>
</context-param>

詳細ロギング

コード リスト 6-6 に表示されるスタンザ例は、詳細ロギングを有効または無効にするのに使用されます。

コード リスト 6-6 詳細ロギング
<context-param>
    <description>Enable verbose logging for the servlet.</description>
    <param-name>enable_verbose_logging</param-name>
    <param-value>true</param-value>
</context-param>

詳細ログ ファイルの場所

コード リスト 6-5 に示されるスタンザ例は、詳細ログ ファイルの場所を指定するのに使用されます。デフォルトで、このファイルはドメインの一時ディレクトリに保存されます。

コード リスト 6-7 詳細ログ ファイルの場所
<context-param>
    <description>Specify the folder to put verbose logs.</description>
    <param-name>verbose_log_folder</param-name>
    <param-value>D:/dev/src/wlp/propagation/test/inventories</param-value>
</context-param>

ページの先頭       前  次