MQSSendPipelineComponent (BizTalk Server サンプル)
このサンプルでは、一連の MQSeries プロパティ値を XML ファイルから読み取って、メッセージに適用する、パイプライン コンポーネントの作成方法を示します。
このサンプルの処理
このサンプルは、パイプライン コンポーネント プロジェクトとパイプライン コンポーネントを使用するパイプライン プロジェクトの 2 つの Visual Studio プロジェクトで構成されています。
このサンプルの場所
<SamplesPath>\AdaptersUsage\MQSeriesAdapter\MQSSendPipelineComponent\SetMQSeriesHeaderPropertyComponent
<SamplesPath>\AdaptersUsage\MQSeriesAdapter\MQSSendPipelineComponent\SetMQSeriesHeaderPropertyPipeline
次の表は、このサンプルのファイルとその目的を示しています。
[最近使ったファイル] | 説明 |
---|---|
SetMQSeriesHeaderPropertyComponent\SetMQSeriesHeaderPropertyComponent.sln、 SetMQSeriesHeaderPropertyComponent\SetMQSeriesHeaderPropertyComponent.csproj |
パイプライン コンポーネントのプロジェクト ファイルとソリューション ファイルです。 |
SetMQSeriesHeaderPropertyComponent\CSetMQSeriesHeaderPropertyComponent.cs | パイプライン コンポーネントの Visual C#® ソース ファイルです。 |
SetMQSeriesHeaderPropertyComponent\SetMQSMQMDHdrProps.xml | パイプライン コンポーネントによって読み取られ、使用される MQSeries プロパティです。 |
SetMQSeriesHeaderPropertyPipeline\SetMQSeriesHeaderPropertyPipeline.btproj、 SetMQSeriesHeaderPropertyPipeline\SetMQSeriesHeaderPropertyPipeline.sln |
BizTalk パイプラインのプロジェクト ファイルとソリューション ファイルです。 |
SetMQSeriesHeaderPropertyPipeline\SetMQSeriesHeaderPropertyPipeline.snk | BizTalk パイプライン プロジェクトの厳密な名前のキー ファイルです。 |
SetMQSeriesHeaderPropertyPipeline\SetMQSeriesHeaderPropertyPipeline.btp | BizTalk Server パイプラインです。 |
このサンプルの使用方法
アプリケーションを作成するには、次の手順を実行します。
アプリケーション用のフォルダーを作成します。
パイプライン コンポーネントの Visual Studio プロジェクトを変更してコンパイルします。
コンパイルしたアセンブリとヘッダー ファイルを適切なフォルダーにコピーします。
BizTalk Server パイプラインの Visual Studio プロジェクトを変更します。
BizTalk Server パイプライン プロジェクトをコンパイルして展開します。
BizTalk Server の受信場所を設定します。
MQSeries キューを作成します。
送信ポートを設定します。
受信場所を有効にして送信ポートを開始します。
アプリケーション用のフォルダーの作成
この手順では、アプリケーション用の適切なフォルダーを作成します。
アプリケーション用のフォルダーを作成するには
まだ存在しない場合は、C:\ ドライブに temp という名前のフォルダーを作成します。
Pickup3 という名前の C:\temp ディレクトリの下にフォルダーを作成します。
パイプライン コンポーネント用のプロジェクトの変更とコンパイル
この手順では、パイプライン コンポーネントの Visual Studio プロジェクトを変更してコンパイルします。
パイプライン コンポーネント用にプロジェクトを変更およびコンパイルするには
ソリューション ファイル SetMQSeriesHeaderPropertyComponent\SetMQSeriesHeaderPropertyComponent.sln をダブルクリックして、Visual Studio でソリューションを開きます。
クラス ファイル CSetMQSeriesHeaderPropertyComponent.cs をダブルクリックして、Visual Studio でクラス ファイルを開きます。
変数 samplesDir を見つけて、この変数が C:\temp の場所に設定されていることを確認します。
ソリューション エクスプローラーでソリューションを右クリックし、[ビルド] をクリックします。 これにより、 プロジェクトが SetMQSeriesHeaderPropertyComponent\SetMQSeriesHeaderPropertyComponent\bin\Debug\ ディレクトリにある dll にコンパイルされます。
適切なフォルダーへのアセンブリとヘッダー ファイルのコピー
この手順では、コンパイルしたアセンブリとヘッダー ファイルを適切なフォルダーにコピーします。
コンパイルしたアセンブリとヘッダー ファイルを適切なフォルダーにコピーするには
コンパイル済みアセンブリ SetMQSeriesHeaderPropertyComponent.dll を BizTalk パイプライン コンポーネント フォルダーにコピーします。 BizTalk パイプライン コンポーネント フォルダーの既定の場所は、\Program Files (x86)\Microsoft BizTalk Server <VERSION>パイプライン コンポーネントです。
SetMQSMQMDHdrProps.xml MQHeader プロパティ ファイルを C:\temp ディレクトリにコピーします。
BizTalk Server パイプライン用のプロジェクトの変更
この手順では、BizTalk Server パイプラインの Visual Studio プロジェクトを変更します。
BizTalk Server パイプライン用にプロジェクトを変更するには
Visual Studio で、ソリューション ファイル SetMQSeriesHeaderPropertyPipeline\SetMQSeriesHeaderPropertyPipeline.sln をダブルクリックしてソリューションを開きます。
プロジェクトの厳密な名前キー ファイルを作成します。 Live Unit Testing を有効にするには、次の手順を実行します。
Visual Studio 2005 コマンド プロンプトを開きます。
ディレクトリを <SamplesPath>\AdaptersUsage\MQSeriesAdapter\MQSSendPipelineComponent に変更します。
次のように入力します。
sn -k MQSSendPipelineComponent.snk
ENTER キーを押します。 これにより、キー ファイルが作成されます。
ソリューション エクスプローラーでプロジェクトを右クリックし、[プロパティ] をクリックしてプロジェクトのプロジェクト Designerを起動します (中央のウィンドウ)。
[プロジェクト] Designerで、[署名] タブをクリックします。
右側のウィンドウで、[ アセンブリに署名 する] オプションを選択します。
[ 厳密な名前キー ファイルの選択 ] オプションのドロップダウン リストをクリックし、[ 参照] をクリックします。
<SamplesPath>\AdaptersUsage\MQSeriesAdapter\MQSSendPipelineComponent\MQSSendPipelineComponent.snk に移動し、[開く] をクリックします。
前に作成したパイプライン コンポーネントは、このパイプライン プロジェクトの プレアセンブル ステージに既に追加されています。 このコンポーネントがまだ追加されていない場合は、次の手順に従って追加する必要があります。
Visual Studio IDE で、左側の [ ツールボックス ] タブをクリックします。
ツールボックスを右クリックし、[項目の選択] をクリックします。
[ ツールボックス項目の選択 ] ダイアログ ボックスで、[ BizTalk パイプライン コンポーネント ] タブをクリックし、[ MQseries ヘッダー プロパティを設定するカスタム コンポーネント] コンポーネントを選択し、[OK] をクリック します。
[カスタム コンポーネント] を [Set MQseries header properties]\(MQseries ヘッダー プロパティの設定\) コンポーネントを、このパイプラインの [事前アセンブル] ステージにドラッグします。
パイプライン プロジェクトのコンパイルと展開
この手順では、BizTalk Server パイプライン プロジェクトをコンパイルして展開します。
パイプライン プロジェクトをコンパイルおよび展開するには
[ソリューション エクスプローラー] ウィンドウで、ソリューションを右クリックし、[ソリューションの配置] をクリックします。 これにより、ソリューションがビルドされ、アセンブリが BizTalk 管理データベースに展開されます。
次の手順に従って、アセンブリが BizTalk 管理データベースに展開されたことを確認します。
BizTalk 管理コンソールを開きます。
クリックして BizTalk グループ [<servername>:<management database>] を展開し、[アセンブリ] フォルダーをクリックして展開します。
デプロイされたパイプライン アセンブリは、[ アセンブリ ] フォルダーの下に表示されます。
受信場所の作成
この手順では、BizTalk Server の受信場所を作成します。
受信場所を作成するには
BizTalk Server管理コンソールで、[受信ポート] を右クリックし、[新規] をポイントして、[一方向の受信ポート] をクリックします。
[ 一方向の受信ポートのプロパティ ] ダイアログ ボックスの [名前 ] ボックスに「MQReply」と入力し、[OK] をクリック します。
左側のウィンドウで、[ 受信場所 ] タブをクリックし、[ 新規] をクリックします。
[ 受信場所のプロパティ ] ダイアログ ボックスの [名前 ] フィールドに「ReceiveFile」と入力します。
[ トランスポートの種類 ] ボックスで、[ファイル] を選択 します。
[ 受信ハンドラー ] フィールドで、 BizTalkServerApplication を選択します。
[ 受信パイプライン ] フィールドで、[ Microsoft.BizTalk.DefaultPipelines.PassThruReceive] を選択します。
[ 受信フォルダー ] フィールドに、「C:\temp\Pickup3」と入力します。
[ ファイル マスク ] フィールドに「*.*」と入力します。
[ OK] をクリックし、もう一度 [OK] を クリックして [ 受信場所のプロパティ ] ダイアログ ボックスを終了します。
MQSeries エクスプローラーを使用した MQSeries キューの作成
MQSeries Server for Windows インストールに必要な権限がある場合は、アダプター・ダイアログ・ボックスを使用して MQSeries キューを作成できます。この次の手順はスキップできます。
このようなアクセス許可を持っていない場合は、次の手順に従って、IBM WebSphere MQ エクスプローラーを使用してキューを作成できます。
MQSeries エクスプローラーを使用して MQSeries キューを作成するには
[スタート] をクリックし、[プログラム] をポイントし、[WebSphere MQ] をポイントして、[WebSphere MQ エクスプローラー] をクリックします。
[キュー マネージャー] をダブルクリックし、既定のキュー マネージャーをダブルクリックします。 通常、既定のキュー マネージャーの名前は QM_<ですmachine_name>machine_nameはコンピューターの名前です。
[ キュー] を右クリックし、[ 新規] をポイントして、[ ローカル キュー] をクリックします。
[ ローカル キューの作成 ] ダイアログ ボックスの [ キュー名] に「 SETHEADER」と入力し、[OK] をクリック します。
送信ポートと MQSeries キューの作成
この手順では、出力メッセージ用の送信ポートを作成します。 MQSeries キューは、送信ポートがまだ作成されていない場合に送信ポートを作成したときにも作成されます。
送信ポートと MQSeries キューを作成するには
[ 送信ポート] を右クリックし、[ 新規] をポイントして、[ 静的一方向送信ポート] をクリックします。
[ 送信ポートのプロパティ ] ダイアログ ボックスの [名前 ] ボックスに「MQSolicitResponse」と入力します。
[ トランスポートの種類 ] ボックスで、[ MQSeries] を選択します。
[ 送信パイプライン ] ボックスで、[ SetMQSeriesHeaderPropertyPipeline.SetMQSeriesHeadersSendPipeline] を選択します。
[フィルター] で、次の名前と値のペアを持つ新しいエントリを追加します。
プロパティを "BTS" に設定します。ReceivePortName"
演算子を "==" に設定 します 。
値を "ReceiveFile" に設定します。
Note
これにより、ReceiveFile 受信ポートで受信したメッセージをサブスクライブするように送信ポートが設定されます。
[ トランスポート] をクリックします。
[ アドレス (URI)] フィールドで、省略記号 (...) ボタンをクリックします。
[ MQSeries トランスポートのプロパティ ] ダイアログ ボックスの [ キュー定義 ] フィールドで、省略記号 (...) ボタンをクリックします。
[ キュー定義 ] ダイアログ ボックスの [ サーバー名 ] フィールドに、コンピューター名を入力します。
[ キュー マネージャー ] フィールドで、既定のキュー マネージャーを選択します。
[キュー] フィールドに「SETHEADER」と入力し、[ エクスポート] をクリックします。
[ エクスポート ] ダイアログ ボックスで、[ キューの作成] をクリックし、すべてのダイアログを終了するまで [OK] または [完了 ] をクリックします。
受信場所の有効化と送信ポートの開始
この手順では、受信場所を有効化し、送信ポートを開始します。
受信場所を有効にして送信ポートを開始するには
BizTalk Server管理コンソールで、[受信ポート] をクリックします。
詳細ペインで、 MQIn 受信場所を右クリックし、[ 有効にする] をクリックします。
詳細ウィンドウで、 SetMQHeader 送信ポートを右クリックし、[ 開始] をクリックします。
アプリケーションのテスト
この手順では、アプリケーションをテストします。
アプリケーションをテストするには
ファイルを C:\Temp\Pickup3 フォルダーに配置します。
WebSphere MQ エクスプローラーを起動し、SETHEADER キューをダブルクリックして、SETHEADER キュー内のメッセージを検証します。
SETHEADER キュー内のメッセージのすべてのコンテキスト プロパティを表示するには、次の手順に従います。
SETHEADER キューをダブルクリックして、[メッセージ ブラウザー] ダイアログ ボックスを表示します。
[ メッセージ ブラウザー ] ダイアログ ボックスで、[ 列 ] をクリックして [ メッセージの列の表示/非表示 ] ダイアログ ボックスを表示します。
[ 使用可能な列] で、各エントリをダブルクリックして [ メッセージ ブラウザー ] ダイアログ ボックスに表示し、[OK] をクリック します。
各メッセージのメッセージ コンテキスト プロパティは、[ メッセージ ブラウザー ] ダイアログ ボックスに表示されます。