検索

第7章 メッセージの構築

download PDF

概要

メッセージ構築パターンでは、システムを通過するメッセージのさまざまな形式と関数が記述されます。

7.1. 相関識別子

概要

図7.1「相関識別子パターン」相関識別子 (Correlation Identifier) パターンは 、非同期メッセージングシステムを使用してリクエスト−リプライ型プロトコルを実装する場合にリクエストメッセージとリプライメッセージの照合方法を記述します。リクエストメッセージはリクエストメッセージを識別する一意のトークンである リクエスト ID によって生成されます。リプライメッセージには、一致するリクエスト ID が含まれるトークンである 相関 ID が含まれる必要があります。

Apache Camel は、メッセージでヘッダーを取得または設定することにより、EIP パターンからの相関識別子をサポートします。

ActiveMQ または JMS コンポーネントを使用する場合、相関識別子ヘッダーは JMSCorrelationID と呼ばれます。独自の相関識別子をメッセージ交換に追加すると、1 つの会話 (またはビジネスプロセス) で複数のメッセージを一緒に関連付けることができます。通常、相関識別子は Apache Camel メッセージヘッダーに格納されます。

一部の EIP パターンでは、サブメッセージがスピンオフされます。この場合、Apache Camel は、ソースエクスチェンジにリンクする Exchange.CORRELATION_ID キーのあるプロパティーとして相関 ID をエクスチェンジに追加します。たとえば、SplitterMulticastRecipient List、および Wire Tap EIP がこれを行います。

図7.1 相関識別子パターン

相関識別子パターン

イベントメッセージ

Camel は、一方向のイベントメッセージを示すために InOnly に設定できる メッセージ で Exchange パターンをサポートすることにより、エンタープライズ統合パターン からの イベントメッセージ をサポートします。その後、Camel の Apache Camel コンポーネントリファレンス は基盤のトランスポートまたはプロトコルを使用して、このパターンを実装します。

イベントメッセージソリューション

多くの Apache Camel コンポーネントリファレンス のデフォルト動作は、JMSFile、または SEDA などに対して InOnly です。

明示的な InOnly の指定

デフォルトが InOut であるコンポーネントを使用している場合、pattern プロパティーを使用して、エンドポイントの メッセージ交換パターン を上書きできます。

foo:bar?exchangePattern=InOnly

Camel 2.0 以降では、DSL を使用して メッセージ交換パターン を指定できます。

Fluent Builder (流れるようなビルダー) の使用

from("mq:someQueue").
  inOnly().
  bean(Foo.class);

または、明示的なパターンでエンドポイントを呼び出すこともできます。

from("mq:someQueue").
  inOnly("mq:anotherQueue");

Spring XML エクステンション の使用

<route>
    <from uri="mq:someQueue"/>
    <inOnly uri="bean:foo"/>
</route>
<route>
    <from uri="mq:someQueue"/>
    <inOnly uri="mq:anotherQueue"/>
</route>
Red Hat logoGithubRedditYoutubeTwitter

詳細情報

試用、購入および販売

コミュニティー

Red Hat ドキュメントについて

Red Hat をお使いのお客様が、信頼できるコンテンツが含まれている製品やサービスを活用することで、イノベーションを行い、目標を達成できるようにします。

多様性を受け入れるオープンソースの強化

Red Hat では、コード、ドキュメント、Web プロパティーにおける配慮に欠ける用語の置き換えに取り組んでいます。このような変更は、段階的に実施される予定です。詳細情報: Red Hat ブログ.

会社概要

Red Hat は、企業がコアとなるデータセンターからネットワークエッジに至るまで、各種プラットフォームや環境全体で作業を簡素化できるように、強化されたソリューションを提供しています。

© 2024 Red Hat, Inc.