TPE の考慮事項と既知の問題
追跡プロファイルと TPE を操作する際に留意しなければならない点は次のとおりです。
TPE でのフォルダー名の付け方
追跡プロファイル エディターでフォルダーに名前を付ける場合は、次の命名規則に従ってください。
フォルダー名とデータ項目インスタンス値を合わせた長さは 128 文字を超えないようにする必要があります。
Continuation および ContinuationID フォルダーの場合、フォルダーの名前付けは、2 つのオーケストレーションを相関付ける際に非常に重要になります。 たとえば、オーケストレーション A がオーケストレーション B の親である場合、オーケストレーション A には、オーケストレーション B 内の ContinuationID フォルダーに直接マップされる名前を持つ Continuation フォルダーが含まれています。
TPE のオーケストレーションの開発
無効な図形で開始する、または終了するビジネス アクティビティにオーケストレーションをマップすることはできません。 オーケストレーション エンジンでは、一部の図形を追跡できない場合があります。 これらは次のとおりです。
メッセージの割り当て
変換
グループ (タスク)
[中断]
ループ (While)
[Branch]\(ブランチ)
Terminate
Throw
キャッチ
While 図形
追跡プロファイル エディターやその他の BAM ツールでビジネス アクティビティを利用できるように、ビジネス アクティビティへのマップを行う場合は、次のガイドラインに従ってください。
グループ図形の場合は、トランザクション以外のスコープ図形を使用します。
While 図形の場合は、トランザクション以外のスコープ図形内にラップします。
終了図形の場合、通常のシナリオでは終了図形の End イベントが発生しないので、回避策はありません。
ドラッグ アンド ドロップ操作が許可されていない図形を使用してスケジュールの開始または終了を行わないでください。
実行中のプロセスを監視する追跡プロファイルの適用
追跡プロファイルを更新する場合に、アクティビティに BAM の Continuation が含まれていると、実行中のアクティビティ インスタンスに影響することがあります。 具体的には、追跡プロファイルの更新によって、既に記録されているアクティビティ項目に対してデータの下流傍受が指定されると、元の値が上書きされる可能性があります。 各ストリーム オブジェクトは、アクティビティまたはストリームが開始された時点で配置されたプロファイルの特定のバージョンに関連付けられているため、すべての単一のイベント ストリームは、実質的には追跡プロファイルの更新対象のアプリケーションによる影響を受けません。 ただし、Continuation は複数のイベント ストリームを関連付ける手段なので、プロファイルの更新の時点でまだ開始されていなかったストリームは、更新中に変更内容を取得します。その結果、上記のようなデータの上書きが発生する可能性があります。 継続の詳細については、「アクティビティの継続」および「継続を作成する方法」を参照してください。
メッセージ プロパティを作成するときの起点となる送信図形や受信図形のないプロファイルの追跡
Continuation は、アクティビティ間で共通するコンテキスト プロパティまたはペイロード データを通じてアクティビティを追跡するプロセスです。 メッセージ ID、サービス ID、インスタンス ID などのプロパティの値は、アクティビティ間で変化します。
このようなシナリオを処理する追跡プロファイルは、次の方法で作成できます。
動的バインドを通じてあるオーケストレーションから別のオーケストレーションにメッセージが送信される場合、グローバルな一意のペイロード データ値を Continuation に使用できます。
メッセージ内に一意のペイロード データが含まれていない場合は、メッセージのインターチェンジ ID を使用できます。 インターチェンジ ID を使用するには、これを同じ受信図形上で追跡する必要があります。 新しいメッセージを作成する場合はインターチェンジ ID が変更されるため、インターチェンジ ID を使用してメッセージを新規作成することはできません。 受信図形または送信図形以外の図形からインターチェンジ ID を追跡すると、信頼性が低下します。
また、パイプライン経由で受信されたものとまったく同じメッセージをオーケストレーション内で使用する限り、つまり、オーケストレーション ポートがパイプラインにバインドされており、受信図形とメッセージ ID がその場所から追跡される場合に限り、メッセージ ID を使用することもできます。 異なる図形からメッセージ ID を追跡すると、そのメッセージ ID は無効となり、Continuation で使用できなくなります。
オーケストレーションが別のオーケストレーションを呼び出してメッセージが渡されない場合、またはオーケストレーションが別のオーケストレーションを呼び出しても、呼び出し先にペイロード データ値を取得できるコンストラクト、受信、または送信図形がない場合、ユーザーはインスタンス ID を使用できます。 呼び出されたオーケストレーションのインスタンス ID は変更されません。
オーケストレーションが、直接呼び出しではなく実行呼び出しによって別のオーケストレーションを読み込む場合は、静的メッセージ プロパティを使用してアクティビティを追跡することはできません。 つまり、Continuation を有効にすることはできません。 このようなオーケストレーション インスタンスで追跡を実行する唯一の方法は、追跡の実行対象となる一意のペイロード データを含んでいるパイプラインを経由してメッセージを渡すことです。
パススルー パイプラインの場合、継続トークンとしてセッション ID を使用できない
追跡プロファイルでは、メッセージ ペイロードから項目を選択すると、追跡プロファイルはそのメッセージのスキーマにバインドされます。 パススルー パイプライン内では、スキーマ名の値が NULL 値となります。 BAM が、ポート名別およびスキーマ名別に構成を読み込もうとした場合、セッション ID スキーマとの照合を行うことはできず、エンジンによるデータ追跡は行われません。
パススルー パイプラインの場合、追跡プロファイルからすべてのペイロード追跡を削除できます。また、ペイロード データの追跡が必要であれば、XML パイプラインの使用も可能です。
一意のポート名の使用
双方向ポートを列挙する場合、TPE により、ポートは 2 つの論理ポート (送信ポートと受信ポート) として表示されます。 これらの各論理ポートは、同じ名前で表示されます。 BizTalk Server では、一方向ポートと双方向ポートを同じ名前で作成できます。 たとえば、"Port1" という名前の双方向ポートを作成してから、同じ名前の受信ポートを作成できます。 この場合、TPE には受信ポートは一度だけ表示され、双方向は 2 回 (1 回は受信ポートとして、もう 1 回は送信ポートとして) 表示されます。
TPE は、この場合、両方の受信ポートに追跡プロファイルを適用します。 識別しやすいように、ポートには一意の名前を割り当てるようにしてください。
最初の図形が平行図形である TPE オーケストレーションの使用
分岐図形、平行図形、待ち受け図形が含まれたオーケストレーションを開始する場合、いずれかの分岐にアクティビティ ID をマップすることはできません。 平行処理の場合は、分岐図形の上層にアクティビティ ID をマップできます。 また、BAM によってアクティビティ ID を生成し、オーケストレーションの最上層で平行図形の問題を回避することもできます。
重要
アクティビティを複数のパスにマップするだけでなく、分岐図形のいずれかのパスにアクティビティ ID をマップすると、アクティビティ ID がマップされていないパスに沿って処理が進められた場合にエラーが発生します。
デザイン時のメッセージ プロパティの可用性
追跡プロファイルを作成する際、一部のメッセージ プロパティを利用できない場合があります。 たとえば、メッセージ プロパティのマップ元となる図形がオーケストレーションの最上部に位置している場合などです。 このようなオーケストレーション インスタンスでは、メッセージ プロパティの値は NULL 値になります。
その例として、待ち受け図形がオーケストレーションの最初の図形である場合が挙げられます。 この図形からメッセージ プロパティをマップする場合、InstanceID、ServiceID、ServiceClassID の各プロパティのみが値を持ちます。 ただし、MessageID はこの時点ではスコープ外となるので、NULL 値を持ちます。
ループ図形内部の図形をマップしてマイルストーンを報告することはできない
TPE では、ループ図形内部にあるソースを、ループ図形外部の項目にマップされているアクティビティに割り当てることはできません。
ループ アクティビティとは、オーケストレーション内でループ処理される、つまり反復するアクションのことです。 オーケストレーション内でループ処理されるアクションからイベントをキャプチャできます。 この操作を行うには、アクティビティをもう 1 つ作成し、ループ内の新しいアクティビティ マイルストーンとデータのすべてをマップします。 ループ内でのデータ処理は、スケジュールされた実行ごとに 1 回以上行われるので、この操作が必要です。
たとえば、ループ内で処理される複数の品目が注文書に記載されている場合、「100 ドルの価格があるのはどの注文書か」というような質問は、あいまいです。 質問を明確にすると、次のようになります。
価格が 100 ドルの品目があるのはどの注文書か
合計/最低/最高 100 ドルの価格があるのはどの注文書か
明確な質問を作成するには、注文書とは別のものとして品目を考える必要があります。 追跡プロファイル エディターでは、ルート アクティビティ (注文書など) はループの外側のすべてのアクションにマップされます。 子アクティビティ (品目など) はループ内のアクションにマップされます。
このような構造を操作するには、通常、反復ループを分解し、外部アクティビティに関連付けられている内部アクティビティに基づいて関連アクティビティを作成します。
ルート アクティビティの ActivityID としてペイロード項目を使用し、このペイロード項目を、ループ内部の一部のメッセージで利用できるようにする必要があります。 子アクティビティの下に表示されるリレーションシップ ノードにアクティビティをマップし、ルート アクティビティとして名前を付けます。
複数のアプリケーションにまたがるプロファイルの追跡
追跡プロファイルが複数のアプリケーションにまたがっている場合、追跡プロファイルは、ソリューション内のすべてのアプリケーションが展開された後に展開する必要があります。 追跡プロファイルが最後に展開されたアイテムでない場合は、展開ウィザードが BTTDeploy.exe を呼び出すと、"マッピング ソースが見つかりません。" というメッセージが表示されます。
複数の BizTalk Server アイテムのドキュメント参照 URL または MessageID ノードへのマップ
TPE では、複数の BizTalk Server アイテムを同じドキュメント参照 URL ノードや MessageID ノードにドラッグ アンド ドロップできます。
複数のソースが BAM アクティビティ内の同じ項目にマップされている場合、BAM 処理時に発生した最後のアイテムが追跡データに保持され、BAM ポータルで表示可能になります。
BizTalk ソリューション バージョンに合わせた BTT バージョンの更新
BAM 開発者や管理者は、BTT ファイルを自動更新することにより、追跡プロファイルと BizTalk ソリューションのバージョン同期を維持できます。 これを行うには、BTT ファイルの DataLevel 要素の Version 属性を変更します。 次の例では、TargetAssemblyName および SchemaName 属性を使用してバージョン情報を変更します。
<DataLevel Name="City" SourceTypeSelected="Messaging Payload" TargetAssemblyName="TheImplementationOfOrderMgmt, Version=1.0.0.0, Culture=neutral, PublicKeyToken=c5b33e44ffa4658b" SchemaName="TheImplementationOfOrderMgmt.PurchaseOrder,TheImplementationOfOrderMgmt, Version=1.0.0.0, Culture=neutral, PublicKeyToken=c5b33e44ffa4658b" SomXPath="/*[local-name()='<Schema>' and namespace-uri()='http://TheImplementationOfOrderMgmt.PurchaseOrder']/*[local-name()='PurchaseOrder' and namespace-uri()='http://TheImplementationOfOrderMgmt.PurchaseOrder']/*[local-name()='Header' and namespace-uri()='']/*[local-name()='ShipTo' and namespace-uri()='']/@*[local-name()='City' and namespace-uri()='']" XPath="/*[local-name()='PurchaseOrder' and namespace-uri()='http://TheImplementationOfOrderMgmt.PurchaseOrder']/*[local-name()='Header' and namespace-uri()='']/*[local-name()='ShipTo' and namespace-uri()='']/@*[local-name()='City' and namespace-uri()='']" IsBeginActivity="true" IsEndActivity="false">
TPE で一部のオーケストレーション図形を追跡できない
オーケストレーション エンジンは次の図形についてイベントを生成できないので、これらの図形を TPE で追跡またはマップすることはできません。
タスク
すべての分岐
[中断]
Terminate
Throw
キャッチ
メッセージの割り当て (構築図形に含まれているため)
変換 (構築図形に含まれているため)
Loop
展開された追跡プロファイルを取得しない TPE
アップグレードまたは再展開の後、展開された追跡プロファイルを取得できない場合があります。 これは、BizTalkMgmtDb データベースがレジストリ内に保存されているサーバー名に不一致があるために発生します。
BizTalkMgmtDb は、グループの構成中にレジストリに書き込まれます。 TPE はエントリを使用して、プライマリ インポート データベースを検索し、追跡プロファイルをフィルター処理します。
構成中、サーバー名は複数の形式で入力できます。 次に例を示します。
mgmtsvr1316267,15001\inst
MGMTSVR1316267\inst,15001
TPE は、レジストリ エントリの使用時に基本的な文字列比較を実行します。 デプロイされた追跡プロファイルを取得するには、格納されているサーバーとデータベース名を調べて、[TPE 管理データベースの設定 ] ダイアログ ボックスに入力する必要があります。
サーバー名とデータベース名の構文を確認して、それを、BizTalk 管理データベースに入力するには
BizTalk Server Custom Configuration Managerを開きます。 カスタム Configuration Managerの使用については、「BizTalk Serverの構成」を参照してください。
ナビゲーション ウィンドウで、[ グループ ] を選択してグループ構成ページを開きます。
[データ ストア] グリッドで、サーバー名とデータベース名の形式を確認します。
TPE を開き、[ ツール ] メニュー項目を選択します。
[ 管理データベースの設定 ] メニュー項目を選択して、[ 管理データベースの設定 ] ダイアログ ボックスを開きます。
[SQL Server] テキスト ボックスで、[カスタム Configuration Manager グループ] ページの [データ ストア] グリッドの [サーバー名] フィールドで使用したサーバー名を入力します。
[データベース名] テキスト ボックスで、[カスタム Configuration Manager グループ] ページの [データ ストア] グリッドの [データベース名] フィールドで使用したデータベース名を入力します。
[ OK] ボタンをクリックしてエントリを保存します。