JBossFuse-キャメルコンセプト

この章では、さまざまなラクダの概念を理解します。まず、基本的な例を取り上げて、コアコンセプトを理解することから始めましょう。

CamelContext

すべてのラクダアプリケーションには、少なくとも1つのCamelContextがあります。これは、ラクダのルートを追加する場所です。に似ていますApplicationContext 春の。

キャメルコンテキストは、すべてのものをまとめるコンテナと考えることができます。1つのラクダコンテキストは、その中に複数のルートを持つことができます。

ルート

CamelContextには、1つ以上のルートが含まれる場合があります。ルートは、データがラクダのコンテキストで1つのエンドポイントから別のエンドポイントにどのように流れるかを定義する統合ロジックです。

終点

エンドポイントは、システムがメッセージを送受信できるチャネルの終わりです。これは、通信言語で宛先またはソースと呼ばれるものです。

コンポーネント

コンポーネントはCamelの拡張ポイントです。コンポーネントは、テクノロジー、データ形式、トランスフォーマーなどへのインターフェイスにすることができます。また、エンドポイントのファクトリとして機能する場合もあります。

EIP

EIPはEnterpriseIntegrationPatternの略です。これらは、繰り返し発生する問題に対する特定されたよく知られた解決策です。Camelは、ほとんどのエンタープライズ統合パターンをサポートしています。

コンテンツベースのルーター

CBRパターンを使用すると、入力ファイルの内容に従ってデータをルーティングできます。

このパターンは、入力の本文の内容に応じて値をルーティングする必要がある場合に使用されます。

次の例では、からデータを読み取ります D:/data/inputディレクトリ。読み取った後、データタグ内の値タグをチェックします。値タグにが含まれている場合value1、に送信されます D:/value1、含まれている場合 value2、に送信されます D:/value2 これらの両方がない場合は、他の人に送信されます。

<CamelContext xmlns = "http://camel.apache.org/schema/spring">
   <route>
      <from uri = "file:///D:/data/input"/>
      <choice>
         <when>
            <xpath>/data/value = 'value1'</xpath>
            <to uri = "file:///D:/value1"/>
         </when> 
         <when>
            <xpath>/data/value = 'value2'</xpath>
            <to uri = "file:///D:/value2"/>
         </when>  
			
         <otherwise>
            <to uri = "file:///D:/others "/>
         </otherwise>
			
      </choice>
   </route>
</camelContext>

Input

D:/data/input/message1.xml

<data>
   <value>value1</value>
</data>

D:/data/input/message2.xml

<data>
   <value>value2</value>
</data>

Output

D:/ value1 /

<data>
   <value>value1</value>
</data>

D:/ value2 /

<data>
   <value>value2</value>
</data>

スプリッター

スプリッターパターンは、入力データをより小さなチャンクに分割するために使用されます。

このパターンは、チャンクに分割する必要がある巨大なデータ入力でほとんどの場合使用されるため、処理可能になります。入力トークン文字列に基づいて、入力をより小さなフラグメントに分割します。

<CamelContext xmlns = "http://camel.apache.org/schema/spring">
   <route>
      <from uri = "file:///D:/inbox"/>
      <split streaming = "true">
         <tokenize token = "order" xml = "true"/>
         <to uri = "activemq:queue:order"/>
      </split>
   </route>
</CamelContext>

Input

D:/inbox/message.xml

<order>
   <data>
      <value>value1</value>
   </data>
</order>

<order>
   <data>
      <value>value2</value>
   </data>
</order>

<order>
   <data>
      <value>value3</value>
   </data>
</order>

Output

AMQをチェックすると、3つのメッセージが投稿されていることがわかります。

<order>
   <data>
      <value>value4</value>
   </data>
</order>

受信者リスト

受信者リストパターンは、受信者のリストをメッセージ本文自体から取得する必要がある場合に使用されます。

次の例では、customerタグにコンマ区切りの文字列リストとしてリストされているすべての受信者にメッセージが送信されます。

<CamelContext xmlns = "http://camel.apache.org/schema/spring">
   <route>
      <from uri = "jms:xmlOrders" />
      <recipientList>
         <xpath>/order/customer</xpath>
      </recipientList>
   </route>
</camelContext>

その他のEIP

Camelは、特定されたほぼすべてのEIPをサポートします。一般的に使用されるEIPのいくつかは以下のとおりです。

  • Log −メッセージ全体またはその一部をログに記録する

  • Message Filter −メッセージの内容のフィルタリング

  • Re-Sequencer −すべてのトークンを順番に取得するには

  • Wiretap −移動メッセージを検査する

EIPとその使用法の完全なリストは、Camelの公式ドキュメントにあります。 http://camel.apache.org/eip.html

Camelでの例外処理

Using Error Handler −これはラクダの例外を処理する最も簡単な方法です。

これを使用するには、エラーハンドラークラスBeanを構成し、それを参照として提供する必要があります。 CamelContext errorHandlerRef 属性。

<bean id = "loggingErrorHandler" class = "org.apache.camel.builder.LoggingErrorHandler">
   <property name = "logName" value = "mylogger.name"/>
   <property name = "level" value = "DEBUG"/>
</bean>

<camelContext errorHandlerRef = ” loggingErrorHandler” >
   …
</camelContext>

最後にキャッチを試すを使用する

キャメルはJavaスタイルもサポートしています Try Catch Finally block エラー処理用。

Javaと同様に、次の3つのブロックがあります-

  • doTry ブロックには、例外を生成する可能性のあるコードが含まれています。

  • doCatch ブロックには、例外が発生した場合に実行する必要のあるコードが含まれています。

  • doFinallyブロックには、例外に関係なく実行する必要のあるコードがあります。例外が発生したかどうかに関係なく、常に実行されます。

Note−モックはコンポーネントをテストしているため、他の目的にはお勧めしません。これは、テスト駆動開発のjMOckコンポーネントと同様に、テストに使用されるラクダのコンポーネントです。

<route>
   <from uri = "direct:start"/>
   <doTry>
      <process ref = "someProcesorThatmayFail"/>
      <to uri = "mock:result"/>
		
      <doCatch>
         <exception>java.io.IOException</exception>
         <exception>java.lang.IllegalStateException</exception>
         <to uri = "mock:catch"/>
      </doCatch>
		
      <doFinally>
         <to uri = "mock:finally"/>
      </doFinally>
		
   </doTry>
</route>

上記の例では、catchブロックで処理する必要のある例外のリストを指定できます。

バンドルをFuseにデプロイする

を使用してFuseを開始します Fuse.bat/start.bat

start.batを使用してFuseを起動する場合は、client.batを使用してFuseに接続します。次のスクリーンショットに示すようなUIが表示されます。

これは、KarafおよびFuseコマンドにアクセスするためのCLIです。

install –s mvn:group.id /artifact.id/version 
e.g. install –s mvn:com.tutorialpoint.app/camel-firt-app/1.0-SNAPSHOT