ApacheCamel-クイックガイド

インドのBigbasketのようなあなたの町の大きなオンライン食料品店があなたに彼らのためのITソリューションを設計するように誘う状況を考えてみてください。安定したスケーラブルなソリューションは、今日直面しているソフトウェアメンテナンスの問題を克服するのに役立ちます。このオンラインストアは、過去10年間ビジネスを運営しています。ストアは、顧客からのさまざまなカテゴリの製品のオンライン注文を受け付け、それらをそれぞれのサプライヤに配布します。たとえば、石鹸、油、牛乳を注文するとします。これらの3つのアイテムは、3つのそれぞれのサプライヤーに配布されます。次に、3つのサプライヤが共通の配布ポイントにサプライ品を送り、そこから配送センターが注文全体を処理します。それでは、彼らが今日直面している問題を見てみましょう。

このストアが営業を開始したとき、コンマで区切られたプレーンテキストファイルで注文を受け付けていました。ある期間にわたって、ストアはメッセージ主導の注文に切り替えました。その後、一部のソフトウェア開発者はXMLベースの注文を提案しました。最終的に、ストアはWebサービスインターフェイスを採用しました。さて、ここに本当の問題があります。現在、注文はさまざまな形式で提供されています。明らかに、会社が注文受付フォーマットをアップグレードするたびに、顧客の心に混乱を引き起こさないように、以前に展開されたインターフェースを壊したくありませんでした。

同時に、ビジネスが成長し続けるにつれて、ストアは定期的に新しいサプライヤーをレパートリーに追加しました。このような各サプライヤには、注文を受け入れるための独自のプロトコルがありました。もう一度、統合の問題に直面します。当社のアプリケーションアーキテクチャは、独自の発注メカニズムを備えた新しいサプライヤに対応するためにスケーラブルである必要があります。

全体の状況を次の図に示します-

ここで、Apache Camelがどのように救助に来て、説明されているシナリオにエレガントで保守可能でスケーラブルなソリューションアーキテクチャを提供できるかを見てみましょう。

ソリューションを進める前に、小さな仮定を立てる必要があります。このチュートリアルのすべての説明では、オンライン注文はXML形式で行われると想定しています。ディスカッション全体で使用する注文ファイルの一般的な形式を次に示します-

<?xml version = "1.0" encoding = "UTF-8"?>
<OrderID Order = "001">
   <order product = "soaps">
      <items>
         <item>
            <Brand>Cinthol</Brand>
            <Type>Original</Type>
            <Quantity>4</Quantity>
            <Price>25</Price>
         </item>
         <item>
            <Brand>Cinthol</Brand>
            <Type>Lime</Type>
            <Quantity>6</Quantity>
            <Price>30</Price>
         </item>
      </items>
   </order>
   
   <order product = "Oil">
      <items>
         <item>
            <Brand>Saffola</Brand>
            <Type>Gold</Type>
            <Quantity>2</Quantity>
            <Price>649</Price>
         </item>
         <item>
            <Brand>Fortune</Brand>
            <Type>Sunlite</Type>
            <Quantity>1</Quantity>
            <Price>525</Price>
         </item>
      </items>
   </order>
   
   <order product = "Milk">
      <items>
         <item>
            <Product>Milk</Product>
            <Brand>Amul</Brand>
            <Type>Pure</Type>
            <Quantity>2</Quantity>
            <Price>60</Price>
         </item>
      </items>
   </order>
</OrderID>

このチュートリアルでは、上記のXMLテンプレートを使用して、Camelの例を説明します。

Camelは、あるエンドポイントからメッセージを受信し、それを別のエンドポイントに送信するブラックボックスです。ブラックボックス内で、メッセージは処理されるか、単にリダイレクトされます。

では、なぜこのためのフレームワークがあるのでしょうか。導入のケーススタディに見られるような実際の状況では、ftp、http、jmsなどの独自のプロトコルに従う多くの送信者と多くの受信者が存在する可能性があります。システムでは、送信者AからのメッセージをB&Cにのみ配信する必要があるなど、多くの複雑なルールが必要になる場合があります。状況によっては、受信者が期待する別の形式にメッセージを変換する必要があります。この翻訳は、メッセージの内容に基づいて特定の条件の対象となる場合があります。したがって、基本的に、プロトコル間で変換し、コンポーネントを結合し、ルーティングルールを定義し、メッセージの内容に基づいてフィルタリングを提供する必要がある場合があります。これを次の図に示します-

上記の要件を満たし、そのような多くの状況に適したソフトウェアアーキテクチャを設計するために、エンタープライズ統合パターン(EIP)は2003年にGregorHohpeとBobbyWoolfによって文書化されました。ApacheCamelはこれらのパターンの実装を提供し、このチュートリアルの目的は教えることです。はじめに説明したような状況でCamelを使用する方法。

ApacheCamelはオープンソースフレームワークです。これは、ルールベースのルーティングおよびメディエーションエンジンを提供するメッセージ指向ミドルウェアです。「牛乳」注文の場合は牛乳ベンダーにリダイレクトし、「石油」注文の場合は石油ベンダーにリダイレクトするなどのルールを定義できます。Camelを使用すると、これらのルールを実装し、使い慣れたJavaコードでルーティングを行うことができます。これは、使い慣れたJava IDEを使用して、タイプセーフな環境でこれらのルールを定義できることを意味します。通常はかさばる傾向があるXML構成ファイルを使用する必要はありません。ただし、ルールの構成にXMLを使用する場合は、CamelはSpringフレームワークを介したXML構成をサポートします。Scalaが好きな場合は、BlueprintXML構成ファイルやScalaDSLを使用することもできます。また、お気に入りのJava、Scala IDE、または単純なXMLエディターを使用してルールを構成できることも意味します。

このエンジンへの入力は、コンマ区切りのテキストファイル、POJO(Plain Old Java Object)、XMLはCamelでサポートされている他のいくつかの形式のいずれかです。同様に、エンジンの出力をファイル、メッセージキュー、またはモニター画面にリダイレクトして、それぞれのベンダーに送信された注文を表示することもできます。これらはエンドポイントと呼ばれ、CamelはメッセージエンドポイントEIPパターンをサポートします。Camelエンドポイントについては、エンドポイントの章で後述します。

Camelは通常、Apache ServiceMix、Apache ActiveMQ、およびApache CXFとともに使用され、サービス指向アーキテクチャーを実装します。

Apache Camelの概要を見てきたので、次にその機能を詳しく調べて、ApacheCamelが何を提供するかを見てみましょう。Apache Camelは、基本的にさまざまなEIPの実装を提供するオープンソースのJavaフレームワークであることはすでに知っています。Camelは、非常に多種多様なトランスポートおよびAPIへの接続を提供することにより、統合を容易にします。たとえば、JMSからJSON、JSONからJMS、HTTPからJMS、FTPからJMS、さらにはHTTPからHTTP、およびマイクロサービスへの接続を簡単にルーティングできます。両端に適切なエンドポイントを指定するだけです。Camelは拡張可能であるため、将来的にはより多くのエンドポイントをフレームワークに簡単に追加できます。

EIPとトランスポートを相互に接続するには、Java、Scala、Groovyなどのドメイン固有言語(DSL)を使用します。典型的なJavaルーティングルールは次のようになります-

from ("file:/order").to("jms:orderQueue");

このルーティングルールは、ファイルを order ディレクトリは、ファイルの内容を含むJMSメッセージを作成し、そのメッセージをというキューに送信します。 orderQueue

Camelアプリケーションの開発に役立つCamelの最も重要な機能のいくつかを次に示します-

  • Camelは、このようなメッセージ変換のためのプラグ可能なデータ形式とタイプコンバーターをサポートしているため、将来、新しい形式とコンバーターを追加できます。現在、いくつかの一般的なフォーマットとコンバーターをサポートしています。いくつか例を挙げると、CSV、EDI、JAXB、JSON、XmlBeans、XStream、Flatpack、Zipです。

  • Camelは、DSLで述語を書くためのプラグ可能な言語をサポートしています。サポートされている言語には、JavaScript、Groovy、Python、PHP、Ruby、SQL、XPath、XQueryなどがあります。

  • CamelはPOJOモデルをサポートしているため、さまざまなポイントでJavabeansをプラグインできます。

  • Camelは、メッセージングを使用することにより、このような大規模な分散および非同期システムのテストを容易にします。

Camelのアーキテクチャを理解し、さまざまな機能がどのように実装されているかを見てみましょう。

Camelアーキテクチャは、統合エンジンとルーター、プロセッサ、およびコンポーネントの3つのコンポーネントで構成されています。これを次の図に示します-

キャメルコア自体は非常に小さく、13の重要なコンポーネントが含まれています。残りの80以上のコンポーネントはコアの外側にあります。これは、展開場所への依存度を低く維持するのに役立ち、将来的に拡張機能を促進します。ザ・Components モジュールは Endpoint外界へのインターフェース。エンドポイントは、次のようなURIによって指定されますfile:/order そして jms:orderQueue 前の章で見たものです。

ザ・ Processorsモジュールは、エンドポイント間のメッセージを操作および仲介するために使用されます。前述のEIPは、このモジュールに実装されています。現在、EIPブックやその他の便利な処理ユニットに記載されている40以上のパターンをサポートしています。

ザ・ Processors そして Endpoints で一緒に配線されています Integration Engine and RouterDSLを使用するモジュール。これらを配線するときに、フィルターを使用して、ユーザー定義の基準に基づいてメッセージをフィルターに掛けることができます。前述のように、これらのルールを作成するにはいくつかのオプションがあります。これには、Java、Scala、Groovy、さらにはXMLを使用できます。

ここで、キャメルの最も重要なコンポーネントに到達します。これはコアと見なすことができます。 CamelContext

CamelContext 次の図に示すように、Camelの他のすべてのサービスへのアクセスを提供します-

さまざまなサービスを見てみましょう。ザ・RegistryモジュールはデフォルトでJNDIレジストリであり、アプリケーションが使用するさまざまなJavaBeanの名前を保持します。キャメルとスプリングを併用すると、これがスプリングになりますApplicationContext。OSGIコンテナでCamelを使用する場合、これは次のようになります。OSGI registry。ザ・Type converters名前が示すように、入力をある形式から別の形式に変換するさまざまなロード型コンバーターが含まれています。組み込みのタイプのコンバーターを使用することも、独自の変換メカニズムを提供することもできます。ザ・Componentsモジュールには、アプリケーションで使用されるコンポーネントが含まれています。コンポーネントは、自動検出によってロードされます。classpathあなたが指定すること。OSGIコンテナーの場合、これらは新しいバンドルがアクティブ化されるたびにロードされます。すでに議論しましたEndpoints そして Routes前の章で。ザ・Data formats モジュールにはロードされたデータ形式が含まれ、最後に Languages モジュールはロードされた言語を表します。

ここのコードスニペットは、どのように CamelContext Camelアプリケーションで作成されます-

CamelContext context = new DefaultCamelContext();
try {
   context.addRoutes(new RouteBuilder() {
      // Configure filters and routes
   }
}
);

ザ・ DefaultCamelContext クラスはの具体的な実装を提供します CamelContext。にaddRoutes メソッドでは、の匿名インスタンスを作成します RouteBuilder。複数作成できますRouteBuilder複数のルーティングを定義するインスタンス。同じコンテキスト内の各ルートには、一意のIDが必要です。ルートは実行時に動的に追加できます。以前に定義したものと同じIDのルートが、古いルートに置き換わります。

中に入るもの RouteBuilder 次にインスタンスについて説明します。

ルート

ルーターは、メッセージを移動するためのルールを定義します fromtoロケーション。あなたが使うRouteBuilderJavaDSLでルートを定義します。ビルトインを拡張してルートを作成しますRouteBuilderクラス。ルートはで始まりますfromエンドポイントであり、1つ以上のエンドポイントで終了します。2つの間に、処理ロジックを実装します。1つのルート内に任意の数のルートを設定できますconfigure 方法。

ルートが作成される方法の典型的な例を次に示します-

context.addRoutes(new RouteBuilder() {
   @Override
   public void configure() throws Exception {
      from("direct:DistributeOrderDSL")
      .to("stream:out");
   }
}

のconfigureメソッドをオーバーライドします RouteBuilderクラスを作成し、ルーティングとフィルタリングのメカニズムを実装します。現在の場合、エンドポイントから受信した入力をリダイレクトしますDistributeOrderDSL エンドポイントによって指定されたコンソールに stream:out

言語の選択

さまざまな言語でルートを作成できます。同じルートが3つの異なる言語でどのように定義されているかのいくつかの例を次に示します-

Java DSL

from ("file:/order").to("jms:orderQueue");

SpringDSL

<route>
   <from uri = "file:/order"/>
   <to uri = "jms:orderQueue"/>
</route>

Scala DSL

from "file:/order" -> "jms:orderQueue"

フィルター

フィルタを使用して、入力コンテンツの一部を選択します。フィルタを設定するには、任意の述語実装を使用します。フィルタリングされた入力は、目的の宛先エンドポイントに送信されます。この例では、石鹸のすべての注文を除外して、それらをまとめて石鹸サプライヤーに送信できるようにします。

from("direct:DistributeOrderDSL")
   .split(xpath("//order[@product = 'soaps']/items"))
      .to("stream:out");

例では、 xpathフィルタリングの述語。フィルタリングにJavaクラスを使用する場合は、次のコードを使用します-

from("direct:DistributeOrderDSL")
   .filter()
      .method(new Order(),"filter")
         .to("stream:out");

ザ・ Order は、独自のフィルタリングメカニズムを備えたカスタムJavaクラスです。

ここのように、1つのルーティングで複数の述語を組み合わせることができます-

from("direct:DistributeOrderDSL")
   .choice()
      .when(header("order").isEqualTo("oil"))
         .to("direct:oil")
      .when(header("order").isEqualTo("milk"))
         .to("direct:milk")
      .otherwise()
         .to("direct:d");

したがって、すべての「石油」注文は石油ベンダーに送られ、「牛乳」注文は牛乳ベンダーに送られ、残りは共通のプールに送られます。

カスタムプロセッサ

カスタム処理を使用することもできます。以下の例では、というカスタムプロセッサを作成しますmyCustomProcessor ルートビルダーで使用します。

Processor myCustomProcessor = new Processor() {
   public void process(Exchange exchange) {
      // implement your custom processing
   }
};
RouteBuilder builder = new RouteBuilder() {
   public void configure() {
      from("direct:DistributeOrderDSL")
      .process(myProcessor);
   }
};

カスタムプロセッサを選択とフィルタリングとともに使用して、メディエーションとルーティングをより適切に制御できます。

from("direct:DistributeOrderDSL")
   .filter(header("order").isEqualTo("milk"))
      .process(myProcessor);

XMLの使用

必要に応じて、ルートをより大きなXMLで定義することもできます。次のXMLスニペットは、SpringXMLを介したフィルタリングとともにルートを作成する方法を示しています-

<camelContext xmlns = "http://camel.apache.org/schema/spring">
   <route>
      <from uri = "direct:DistributeOrderXML"/>
      <log message = "Split by Distribute Order"/>
      <split>
         <xpath>//order[@product = 'Oil']/items</xpath>
         <to uri = "file:src/main/resources/order/"/>
         <to uri = "stream:out"/>
      </split>
   </route>
</camelContext>

ルートがどのように構築されるかを見てきましたが、エンドポイントを作成するさまざまな手法を見ていきます。

統合コードでエンドポイントがどのように表示されるかについて学習しました。これまで使用してきた表現などfile:/order, jms:orderQueue, direct:distributeOrderDSLエンドポイントです。ご覧のとおり、これらはURI仕様形式に従います。このURIを評価している間、CamelContext を作成します Endpointインスタンス; インスタンス化について心配する必要はありませんEndpoint DSLでの実装。

前の例では、JavaDSLでエンドポイントを次のように指定します-

from ("file:/order").to("jms:orderQueue");

そして春にはここに-

<route>
   <from uri = "file:/order"/>
   <to uri = "jms:orderQueue"/>
</route>

どちらの場合も、エンドポイントは定数文字列です。場合によっては、実行時にこの文字列を作成したいことがあります。Javaを使用してこれを行うことができますStringフォーマッタメソッド。Camelは、実行時にこれらのURI文字列を作成するためのもう1つの簡単なアプローチを提供します。この目的のために、キャメルは提供しますfromF そして toFユーザー指定のパラメーターを持つ引数を受け入れるメソッド。次のステートメントは、toF 方法−

from("direct:distributeOrderDSL”).toF("file://%s?fileName=%s", path, name);

これらのメソッドのため、Java組み込みを使用する必要があります String フォーマッタメソッドは不要です。

Camelは、デフォルトでSimple言語を使用してエンドポイント式を計算します。ザ・Simple 言語は主に評価するために設計されました Expressions そして Predicatesの複雑さについてあまり気にせずに XPath。述語を評価するために、次のような別の言語を組み合わせることができます。xpath デフォルトで Simple言語。これは、プラス記号を使用して他の言語を区切ることによって行われます。ここのコードスニペットは、連結する方法を示していますxpath で書かれた式への文字列 Simple

from("direct:start")
.toD("jms:${orderQueue}+language:xpath:/order/@id");

Spring、ここと同じことを達成できます-

<route>
   <from uri = "direct:start"/>
   <toD uri = "jms:${orderQueue}+language:xpath:/order/@id"/>
</route>

必要な数の言語を連結できます。各言語は、前の言語とはプラス記号で区切られています。サポートされている言語のリストはここにあります。

Camelは、いくつかの構築済みコンポーネントを提供します。

この章では、からのいくつかの重要なコンポーネントについて説明します。 camel-core モジュール。

ザ・ Beanコンポーネントは、BeanをCamelメッセージ交換にバインドします。エンドポイントを作成するためのURIは次のように指定されますbean:beanID、 どこ beanID で指定されているBeanの名前です Registry

JndiContext jndiContext = new JndiContext();
jndiContext.bind("MilkOrder", new MilkOrderProcessor());
CamelContext camelContext = new DefaultCamelContext(jndiContext);

camelContext.addRoutes(new RouteBuilder() {
   public void configure() {
      from("direct:bigBasket")
         .to("bean:MilkOrder?method=placeOrder");
   }
});

エンドポイントがどのように指定されているかに注意してください bean:プロトコル。オプションで、呼び出されるBeanメソッドを指定できます。この場合、呼び出されたメソッドplaceOrderエンドポイント式の評価中に呼び出されます。ザ・MilkOrder のJNDI名です MilkOrderProcessorコードスニペットの最初の2行に登録されているJavabean。の定義MilkOrderProcessor 簡潔にするために、ここではそれ自体を省略しています。

直接

あなたはの使用に気づいたに違いありません Direct前の例では。石油ベンダーに注文を送るために、direct:oilエンドポイント仕様で。の用法Directコンポーネントを使用すると、エンドポイントを同期的に呼び出すことができます。前の例の次の2つのコードスニペットは、Direct

.when(header("order").isEqualTo("oil"))
   .to("direct:oil")

そして、

from("direct:DistributeOrderDSL")
   .process(myProcessor);

ファイル

ザ・ Fileコンポーネントは、マシン上のファイルシステムへのアクセスを提供します。このコンポーネントを使用すると、他のコンポーネントからのメッセージをローカルディスクに保存できます。さらに、他のCamelコンポーネントがローカルファイルを処理できるようにします。どちらでもかまいませんfile:directoryName[?options] または file://directoryName[?options]ファイルコンポーネントを使用する際のURI形式として。このコンポーネントの使用については以前に見てきました-

from ("file:/order").to("jms:orderQueue");

注意してください Fileコンポーネントはデフォルトでディレクトリ名を取ります。したがって、注文ディレクトリの内容が入力内容として扱われます。で特定のファイルを指定するにはorder ディレクトリでは、次のステートメントを使用します-

from ("file:/order?fileName = order.xml").to("jms:orderQueue");

ログ

ザ・ Logコンポーネントを使用すると、基になるロギングメカニズムにメッセージを記録できます。Camelは、さまざまなロギングフレームワークの抽象化としてSimple Logging Facade for Java(SLF4J)を使用しています。あなたは使用することができますjava.util.logging, logback, log4jロギング用。このコードスニペットは、Log コンポーネント-

from("direct:DistributeOrderDSL")
   .to("bean:MilkOrder?method = placeOrder")
   .to("log:com.example.com?level = INFO&showBody = true");

セダ

ザ・ SEDA コンポーネントを使用すると、同じ内の別のエンドポイントを非同期で呼び出すことができます CamelContext。CamelContextインスタンス間で呼び出す場合は、次を使用する必要があります。VM成分。SEDAの使用法をここに示します-

from("direct:DistributeOrderDSL")
// send it to the seda queue that is async
   .to("seda:nextOrder")

このルートでは、注文をにルーティングするだけです。 nextOrder非同期キュー。このキューにサブスクライブしているクライアントは、このキューからメッセージを取得します。

タイマー

ザ・ Timerコンポーネントは定期的にメッセージを送信するために使用されるため、Camelアプリケーションのテスト時に非常に役立ちます。ここのコードスニペットは、2秒ごとにコンソールにテストメッセージを送信します-

from("timer://testTimer?period = 2000")
   .setBody()
   .simple("This is a test message ${header.timer}")
      .to("stream:out");

統合プロジェクトのほとんどは、疎結合のアプリケーションアーキテクチャの作成に役立つため、メッセージングを使用します。メッセージングは​​、同期または非同期のいずれかです。JMSは両方をサポートしますpoint-to-point そして publish-subscribeモデル。あなたはQueue ポイントツーポイントおよび Topicパブリッシュ/サブスクライブモデルの場合。Javaプラットフォームでは、JMS-Java MessagingServiceがメッセージングサーバーへのインターフェイスを提供します。Apache activeMQは、そのようなオープンソースのJMSプロバイダーの1つです。CamelにはJMSプロバイダーは付属していません。ただし、activeMQを使用するように構成できます。このコンポーネントを使用するには、プロジェクトに次のjarを含める必要があります-activemq、camel-spring、およびcamel-jms。

次のコードスニペットは、activeMQ用にCamelを構成する方法を示しています。

<bean id = "jms" class = "org.apache.camel.component.jms.JmsComponent">
   <property name = "connectionFactory">
      <bean class="org.apache.activemq.ActiveMQConnectionFactory">
         <property name = "orderQueue" value = "tcp://localhost:61000" />
      </bean>
   </property>
</bean>

ここで、Camelアプリケーションはと呼ばれるキューのリッスンを開始します orderQueue。キュー自体は、ローカルホストで実行され、ポート61000にリストされているactiveMQメッセージングサーバーにセットアップされます。これが完了すると、アプリケーションは、アプリケーションで定義された任意のエンドポイントからこのキューにメッセージを送受信できます。

最後に、Camelアプリケーションがどのように作成されるかをより深く理解するために、すべてをプロジェクトにまとめる時が来ました。

Mavenを使用してCamelプロジェクトを構築します。ただし、開発にはIntelliJIDEを使用することをお勧めします。このプロジェクトには、任意のIDEを使用できます。

新しいプロジェクトの作成

新しいを作成します Maven プロジェクトし、以下を指定します-

GroupId: Basket
ArtifactId: Basket

プロジェクトのデフォルトの場所を選択するか、必要に応じて選択したディレクトリを指定します。

依存関係の追加

Camelを使用するには、いくつかの依存関係を追加する必要があります。依存関係はに追加されますpom.xml。したがって、pom.xmlを開き、次の2つの依存関係を追加します-

<dependencies>
   <dependency>
      <groupId>org.apache.camel</groupId>
      <artifactId>camel-core</artifactId>
      <version>2.20.0</version>
   </dependency>
   <dependency>
      <groupId>org.apache.camel</groupId>
      <artifactId>camel-stream</artifactId>
      <version>2.20.0</version>
   </dependency>
</dependencies>

Note−アプリケーションには最小限の依存関係が必要です。ライブラリからより多くのCamelコンポーネントを使用する場合、対応する依存関係をこのpom.xmlファイルに追加する必要があります。

JavaDSLの作成

次に、フィルタリングとルーティングのコードをJavaDSLで記述します。と呼ばれる新しいJavaクラスを作成しますDistributeOrderDSL。次のコードを追加します-

public class DistributeOrderDSL {
   public static void main(String[] args) throws Exception {
      CamelContext context = new DefaultCamelContext();
      try {
         context.addRoutes(new RouteBuilder() {
            @Override
            public void configure() throws Exception {
               from("direct:DistributeOrderDSL")
                  .split(xpath("//order[@product='soaps']/items")).to("stream:out");
               
               // .to("file:src/main/resources/order/");
            }
         });
         context.start();
         ProducerTemplate orderProducerTemplate = context.createProducerTemplate();
         InputStream orderInputStream = new FileInputStream(ClassLoader.getSystemClassLoader()
            .getResource("order.xml").getFile());
         orderProducerTemplate.sendBody("direct:DistributeOrderDSL", orderInputStream);
      } finally {
         context.stop();
      }
   }
}

の中に main メソッド、最初に作成します CamelContext で提供されるデフォルトの実装をインスタンス化することによって DefaultCamelContext クラス。

CamelContext context = new DefaultCamelContext();

次に、匿名を作成してルートを追加します RouteBuilder インスタンス-

context.addRoutes(new RouteBuilder() {

オーバーライドします configure 直接URIからルートを追加する方法 DistributeOrderDSLシステムコンソールに。xpathクエリを使用してフィルタリングを提供します。

public void configure() throws Exception {
   from("direct:DistributeOrderDSL")
      .split(xpath("//order[@product = 'soaps']/items")).to("stream:out");
   // .to("file:src/main/resources/order/");
}

ルートを追加した後、コンテキストを開始します-

context.start();

次に、直接URIを作成するためのコードを追加します- DistributeOrderDSL

ProducerTemplate orderProducerTemplate = context.createProducerTemplate();
InputStream orderInputStream = new FileInputStream(ClassLoader.getSystemClassLoader()
   .getResource("order.xml").getFile());

最後に、処理を開始します-

orderProducerTemplate.sendBody("direct:DistributeOrderDSL", orderInputStream);

これで、Java DSLコードが完成したので、アプリケーションをテストする前に残っているのは、 order.xmlプロジェクトにファイルします。この目的のために、「はじめに」の章に示されているサンプルXMLを使用できます。

試験結果

アプリケーションを実行すると、次の出力が表示されます-

<items>
   <item>
      <Brand>Cinthol</Brand>
      <Type>Original</Type>
      <Quantity>4</Quantity>
      <Price>25</Price>
   </item>
   <item>
      <Brand>Cinthol</Brand>
      <Type>Lime</Type>
      <Quantity>6</Quantity>
      <Price>30</Price>
   </item>
</items>

ここには石鹸の注文のみが記載されていることに注意してください。これをローカルファイルに保存したい場合は、コメントしてくださいstream.out 次の行のコメントを削除します configure 方法−

// .to("file:src/main/resources/order/");

次のセクションでは、SpringでCamelを使用する方法を学習します。

ここで、Springを使用して前の章のアプリケーションを再作成します。これにより、DSLではなくXMLでCamelルーティングを作成する方法がわかります。

新しいプロジェクトの作成

新しいを作成します Maven プロジェクトし、以下を指定します-

GroupId: BasketWithSpring
ArtifactId: BasketWithSpring

プロジェクトのデフォルトの場所を選択するか、必要に応じて選択したディレクトリを指定します。

依存関係の追加

以前のアプリケーションで使用したコア依存関係に加えて、Springを使用するにはさらにいくつかの依存関係を追加する必要があります。依存関係はpom.xmlに追加されます。ここで、pom.xmlを開き、次の依存関係を追加します-

<dependencies>
   ...
   <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-context</artifactId>
      <version>5.1.3.RELEASE</version>
   </dependency>
   
   <dependency>
      <groupId>org.apache.activemq</groupId>
      <artifactId>activemq-pool</artifactId>
      <version>5.15.2</version>
   </dependency>
   
   <dependency>
      <groupId>org.apache.activemq</groupId>
      <artifactId>activemq-pool</artifactId>
      <version>5.15.1</version>
   </dependency>
   
   <dependency>
      <groupId>org.apache.camel</groupId>
      <artifactId>camel-spring</artifactId>
      <version>2.15.1</version>
   </dependency>
</dependencies>

Spring用のJavaDSLの作成

ここで、という新しいJavaクラスを作成しましょう。 DistributeOrderXML。次のコードを追加します-

public class DistributeOrderXML {
   public static void main(String[] args) throws Exception {
      ApplicationContext appContext = new ClassPathXmlApplicationContext(
         "SpringRouteContext.xml");
      CamelContext camelContext = SpringCamelContext.springCamelContext(appContext, false);
      try {
         camelContext.start();
         ProducerTemplate orderProducerTemplate = camelContext.createProducerTemplate();
         InputStream orderInputStream = new FileInputStream(ClassLoader.getSystemClassLoader()
            .getResource("order.xml").getFile());
         
         orderProducerTemplate.sendBody("direct:DistributeOrderXML", orderInputStream);
      } finally {
         camelContext.stop();
      }
   }
}

の中に main メソッド、最初にインスタンスを作成します ApplicationContext、Springアプリケーション内の中央インターフェースです。そのコンストラクターで、ルーティングおよびフィルタリング情報を含むXMLファイルの名前を指定します。

ApplicationContext appContext = new ClassPathXmlApplicationContext(
   "SpringRouteContext.xml");

次に、作成します CamelContext 上記で作成したものを指定する ApplicationContext そのパラメータで。

CamelContext camelContext = SpringCamelContext.springCamelContext(appContext, false);

この時点で、ルーティングとフィルタリングが設定されています。したがって、私たちは開始しますCamelContext そのを使用して start方法。前の場合と同様に、order.xmlファイルをロードするためのエンドポイントを定義して処理を開始します。ここで、XMLでルーティングがどのように定義されているかを理解しましょう。

アプリケーションコンテキストの作成

プロジェクトに新しいXMLファイルを追加し、それを呼び出します SpringRouteContext.xml. このファイルに次の内容を切り取って貼り付けます。

<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "
      http://www.springframework.org/schema/beans
      http://www.springframework.org/schema/beans/spring-beans.xsd
      http://camel.apache.org/schema/spring
      http://camel.apache.org/schema/spring/camel-spring.xsd ">
   <camelContext xmlns = "http://camel.apache.org/schema/spring">
      <route>
         <from uri = "direct:DistributeOrderXML"/>
         <log message = "Split by Distribute Order"/>
         <split>
            <xpath>//order[@product = 'Oil']/items</xpath>
            <to uri = "file:src/main/resources/order/"/>
            <to uri = "stream:out"/>
         </split>
      </route>
   </camelContext>
</beans>

ここでは、xpathクエリを次のように定義します。ここで、「oil」のすべての注文を選択していることに注意してください。

<xpath>//order[@product = 'Oil']/items</xpath>

出力エンドポイントは複数です。最初のエンドポイントはorder フォルダと2番目のフォルダはコンソールを指定します。

<to uri = "file:src/main/resources/order/"/>
<to uri = "stream:out"/>

アプリケーションを実行します。

試験結果

アプリケーションを実行すると、画面に次の出力が表示されます。

<items>
   <item>
      <Brand>Cinthol</Brand>
      <Type>Original</Type>
      <Quantity>4</Quantity>
      <Price>25</Price>
   </item>
   <item>
      <Brand>Cinthol</Brand>
      <Type>Lime</Type>
      <Quantity>6</Quantity>
      <Price>30</Price>
   </item>
</items>

チェックしてください order指定したパスのフォルダ。上記のXMLコードを含む新しく作成されたファイルがあります。

結論

Camelは、統合プロジェクトを容易にするためにEIPを実装するすぐに使用できるフレームワークを提供します。ドメイン固有言語でのコーディングとXMLの使用もサポートしています。