Red Hat Camel K is deprecated
Red Hat Camel K is deprecated and the End of Life date for this product is June 30, 2025. For help migrating to the current go-to solution, Red Hat build of Apache Camel, see the Migration Guide.第1章 Camel K インテグレーションをローカルでテストする
この章では、Camel jBang を使用して Camel K インテグレーションをローカルでテストする方法を詳しく説明します。
1.1. Camel jBang を使用して Camel K インテグレーションをローカルでテストする
テストは、アプリケーションのビルド中に繰り返し実行される主要な操作の 1 つです。Camel JBang の登場により、より高い環境に移行する前にローカルでテストと微調整を実行できる統一された場所ができました。
クラウドネイティブ 環境に直接接続されたインテグレーションをテストしたり微調整したりすることは、少々手間のかかる作業です。クラスターに接続している必要があります。または、マシン上でローカル Kubernetes クラスター (Minikube、Kind など) が実行されている必要があります。ほとんどの場合、クラスターの微調整に固有の側面は、開発の後半で実現されます。
したがって、アプリケーションをローカルでテストするより簡単な方法を用意し、クラウドネイティブ環境に典型的なチューニングを適用できるデプロイメントステージに移行することが望ましいと言えます。
kamel local
は、過去にローカルでインテグレーションをテストするために使用されたコマンドです。ただし、これは、Camel アプリケーションをデプロイする場所で、Camel アプリケーションをローカルで独立してテストするために使用される単一の CLI を用意するという Camel コミュニティーによる取り組みと重複しています。
1.1.1. Camel JBang のインストール
まず、jbang
と camel
CLI をインストールして慣れておく必要があります。Camel JBang に関する公式ドキュメント に従って、CLI をローカル環境にインストールできます。この後、Camel JBang を使用して Camel K のインテグレーションをテストする方法を説明します。
1.1.2. シンプルなアプリケーション開発
最初に開発するアプリケーションはシンプルなもので、Camel K を介して Kubernetes に最終的にデプロイされるインテグレーションをテストするときに従う必要があるプロセスを定義します。Camel K インストールで Camel のターゲットバージョンを確認します。この情報を使用すると、後でクラスターにデプロイするのと同じバージョンに対してローカルでテストできるようになります。
$ kamel version -a -v | grep Runtime Runtime Version: 3.8.1 $ kubectl get camelcatalog camel-catalog-3.8.1 -o yaml | grep camel\.version camel.version: 3.8.1
上記のコマンドは、クラスター Camel K インストール内のランタイムで使用されている Camel バージョンを確認するのに役立ちます。ターゲットは Camel バージョン 3.18.3 です。
Camel ルートを初期化する最も簡単な方法は、camel init
コマンドを実行することです。
$ camel init HelloJBang.java
この段階では、インテグレーションに必要なロジックを含むファイルを編集するか、単に実行することができます。
$ camel run HelloJBang.java 2022-11-23 12:11:05.407 INFO 52841 --- [ main] org.apache.camel.main.MainSupport : Apache Camel (JBang) 3.18.1 is starting 2022-11-23 12:11:05.470 INFO 52841 --- [ main] org.apache.camel.main.MainSupport : Using Java 11.0.17 with PID 52841. Started by squake in /home/squake/workspace/jbang/camel-blog 2022-11-23 12:11:07.537 INFO 52841 --- [ main] e.camel.impl.engine.AbstractCamelContext : Apache Camel 3.18.1 (CamelJBang) is starting 2022-11-23 12:11:07.675 INFO 52841 --- [ main] e.camel.impl.engine.AbstractCamelContext : Routes startup (started:1) 2022-11-23 12:11:07.676 INFO 52841 --- [ main] e.camel.impl.engine.AbstractCamelContext : Started java (timer://java) 2022-11-23 12:11:07.676 INFO 52841 --- [ main] e.camel.impl.engine.AbstractCamelContext : Apache Camel 3.18.1 (CamelJBang) started in 397ms (build:118ms init:140ms start:139ms JVM-uptime:3s) 2022-11-23 12:11:08.705 INFO 52841 --- [ - timer://java] HelloJBang.java:14 : Hello Camel from java 2022-11-23 12:11:09.676 INFO 52841 --- [ - timer://java] HelloJBang.java:14 : Hello Camel from java ...
ローカル java プロセスは、Camel アプリケーションの実行とともに開始されます。Maven プロジェクトを作成する必要はありません。すべてのボイラープレートは Camel JBang にあります。ただし、使用されている Camel バージョンがターゲットとするバージョンと異なることに気付くでしょう。これは、Camel JBang が異なるバージョンの Camel を使用しているためです。心配はいりません。実行したい Camel バージョンを指定してこのアプリケーションを再実行できます。
$ jbang run -Dcamel.jbang.version=3.18.3 camel@apache/camel run HelloJBang.java ... [1] 2022-11-23 11:13:02,825 INFO [org.apa.cam.imp.eng.AbstractCamelContext] (main) Apache Camel 3.18.3 (camel-1) started in 70ms (build:0ms init:61ms start:9ms) ...
Camel JBang はデフォルトの Camel バージョンを使用しますが、必要に応じて -Dcamel.jbang.version
オプションを使用して、デフォルトを上書きする Camel バージョンを明示的に設定できます。
次のステップは、Camel K がインストールされている Kubernetes クラスターで実行することです。
ここでは、kamel
CLI の代わりに Camel JBang 用の Camel K プラグインを使用します。この方法では、同じ JBang ツールを使用して、Camel K インテグレーションをローカルで実行することも、Operator を使用して K8s クラスターで実行することもできます。JBang プラグインのドキュメントは、Camel JBang Kubernetes を参照してください。
Camel K Operator は、必要な変換を実行し、予想されるライフサイクルに従ってインテグレーションと関連リソースをビルドすることがわかります。これがライブになると、デプロイされたインテグレーションで通常実行する操作をフォローアップできます。
このプロセスの利点は、ローカルで調整されたインテグレーションに満足するまで、リモートクラスターについて心配する必要がないことです。
1.1.3. クラウド向けの微調整
インテグレーションの準備ができたら、クラスターのデプロイメントに関連するチューニングの種類に注意する必要があります。これにより、開発の初期段階でデプロイメントの詳細について心配する必要がなくなります。または、社内でロールを分離して、ドメインエキスパートがローカルでインテグレーションを開発し、クラスターエキスパートが後の段階でデプロイメントを行うこともできます。
後でクラスター内で微調整が必要になるインテグレーションを開発する方法の例を見てみましょう。
import org.apache.camel.builder.RouteBuilder; public class MyJBangRoute extends RouteBuilder { @Override public void configure() throws Exception { from("file:/tmp/input") .convertBodyTo(String.class) .log("Processing file ${headers.CamelFileName} with content: ${body}") /* .filter(simple("${body} !contains 'checked'")) .log("WARN not checked: ${body}") .to("file:/tmp/discarded") .end() .to("file:/tmp/output"); */ .choice() .when(simple("${body} !contains 'checked'")) .log("WARN not checked!") .to("file:/tmp/discarded") .otherwise() .to("file:/tmp/output") .end(); } }
ディレクトリーにファイルを書き込むプロセスがあります。これらのファイルは、その内容に基づいてフィルタリングする必要があります。反復的に開発を進めていくため、コードコメントは意図的に残しています。インテグレーションの最終バージョンに到達するまで、Camel JBang を使用してローカルでテストを行いました。Filter EIP をテストしましたが、テスト中に代わりに Content Based Router EIP が必要になりました。これは、何かを開発するたびにおそらく起こることなので、よくあるプロセスのように感じるはずです。
準備ができたので、Camel JBang 経由でローカルで最後のテストを実行します。
$ jbang run -Dcamel.jbang.version=3.18.3 camel@apache/camel run MyJBangRoute.java 2022-11-23 12:19:11.516 INFO 55909 --- [ main] org.apache.camel.main.MainSupport : Apache Camel (JBang) 3.18.3 is starting 2022-11-23 12:19:11.592 INFO 55909 --- [ main] org.apache.camel.main.MainSupport : Using Java 11.0.17 with PID 55909. Started by squake in /home/squake/workspace/jbang/camel-blog 2022-11-23 12:19:14.020 INFO 55909 --- [ main] e.camel.impl.engine.AbstractCamelContext : Apache Camel 3.18.3 (CamelJBang) is starting 2022-11-23 12:19:14.220 INFO 55909 --- [ main] e.camel.impl.engine.AbstractCamelContext : Routes startup (started:1) 2022-11-23 12:19:14.220 INFO 55909 --- [ main] e.camel.impl.engine.AbstractCamelContext : Started route1 (file:///tmp/input) 2022-11-23 12:19:14.220 INFO 55909 --- [ main] e.camel.impl.engine.AbstractCamelContext : Apache Camel 3.18.3 (CamelJBang) started in 677ms (build:133ms init:344ms start:200ms JVM-uptime:3s) 2022-11-23 12:19:27.757 INFO 55909 --- [le:///tmp/input] MyJBangRoute.java:11 : Processing file file_1669202367381 with content: some entry 2022-11-23 12:19:27.758 INFO 55909 --- [le:///tmp/input] MyJBangRoute:21 : WARN not checked! 2022-11-23 12:19:32.276 INFO 55909 --- [le:///tmp/input] MyJBangRoute.java:11 : Processing file file_1669202372252 with content: some entry checked
入力ディレクトリーにファイルを追加するテストを行いました。開発クラスターにプロモートする準備ができました。
ここで Camel K JBang プラグインを使用して K8s 上でインテグレーションを実行すると、ツールを切り替える必要がなくなります。
以下のコマンドを実行します。
camel k run MyJBangRoute.java
インテグレーションは正常に開始されましたが、インテグレーションが実行されている Pod
に対してローカルなファイルシステムを使用しています。
1.1.3.1. Kubernetes の微調整
それでは、クラウド用にアプリケーションを設定しましょう。クラウドネイティブ開発では、この新しいパラダイムの動作方法に暗黙的に含まれる一連の課題を考慮する必要があります (12 factors を参照)。
Kubernetes の微調整は、少し難しい場合があります。編集および確認するリソースが多数あります。Camel K は、アプリケーションに必要なチューニングのほとんどを kamel run
コマンド (または modeline) で直接適用できるユーザーフレンドリーな方法を提供します。Camel K トレイト をよく理解する必要があります。
この場合、クラスターで利用した特定のボリュームを使用します。--volume
オプション (mount トレイト の糖衣構文) を使用して簡単に有効にすることができます。他の Pod
からこれらのボリュームを読み書きできます。これは、インテグレーションプロセスのアーキテクチャーによって異なります。
$ kamel run MyJBangRoute.java --volume my-pv-claim-input:/tmp/input --volume my-pv-claim-output:/tmp/output --volume my-pv-claim-discarded:/tmp/discarded --dev ... [1] 2022-11-23 11:39:26,281 INFO [route1] (Camel (camel-1) thread #1 - file:///tmp/input) Processing file file_1669203565971 with content: some entry [1] [1] 2022-11-23 11:39:26,303 INFO [route1] (Camel (camel-1) thread #1 - file:///tmp/input) WARN not checked! [1] 2022-11-23 11:39:32,322 INFO [route1] (Camel (camel-1) thread #1 - file:///tmp/input) Processing file file_1669203571981 with content: some entry checked
このチューニングも繰り返す必要がありますが、少なくともルートの内部はローカルで洗練されているので、デプロイメントの側面のみに焦点を当てる必要があります。そして、準備が整ったら、kamel promote
を利用して、インテグレーションを開発のさまざまな段階に進めていきます。
1.1.4. Kamelet をローカルでテストする方法
Camel JBang のもう 1 つの利点は、Kamelet をローカルでテストできることです。これまで、Kamelet をテストする最も簡単な方法は、Kubernetes クラスターにアップロードし、それを使用して Camel K 経由でインテグレーションを実行することでした。
このスコープ向けにシンプルな Kamelet を開発しましょう。これは、ランダムなコーヒーイベントを生成するために使用している Coffee ソースです。
apiVersion: camel.apache.org/v1 kind: Kamelet metadata: name: coffee-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.7.0-SNAPSHOT" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Coffees" camel.apache.org/kamelet.namespace: "Dataset" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Coffee Source" description: "Produces periodic events about coffees!" type: object properties: period: title: Period description: The time interval between two events type: integer default: 5000 types: out: mediaType: application/json dependencies: - "camel:timer" - "camel:http" - "camel:kamelet" template: from: uri: "timer:coffee" parameters: period: "{{period}}" steps: - to: https://random-data-api.com/api/coffee/random_coffee - removeHeaders: pattern: '*' - to: "kamelet:sink"
これをテストするには、単純なインテグレーションを使用してそのコンテンツをログに記録します。
- from: uri: "kamelet:coffee-source?period=5000" steps: - log: "${body}"
次に、以下を実行できます。
$ camel run --local-kamelet-dir=</path/to/local/kamelets/dir> coffee-integration.yaml 2022-11-24 11:27:29.634 INFO 39527 --- [ main] org.apache.camel.main.MainSupport : Apache Camel (JBang) 3.18.1 is starting 2022-11-24 11:27:29.706 INFO 39527 --- [ main] org.apache.camel.main.MainSupport : Using Java 11.0.17 with PID 39527. Started by squake in /home/squake/workspace/jbang/camel-blog 2022-11-24 11:27:31.391 INFO 39527 --- [ main] e.camel.impl.engine.AbstractCamelContext : Apache Camel 3.18.1 (CamelJBang) is starting 2022-11-24 11:27:31.590 INFO 39527 --- [ main] org.apache.camel.main.BaseMainSupport : Property-placeholders summary 2022-11-24 11:27:31.590 INFO 39527 --- [ main] org.apache.camel.main.BaseMainSupport : [coffee-source.kamelet.yaml] period=5000 2022-11-24 11:27:31.590 INFO 39527 --- [ main] org.apache.camel.main.BaseMainSupport : [coffee-source.kamelet.yaml] templateId=coffee-source 2022-11-24 11:27:31.591 INFO 39527 --- [ main] e.camel.impl.engine.AbstractCamelContext : Routes startup (started:2) 2022-11-24 11:27:31.591 INFO 39527 --- [ main] e.camel.impl.engine.AbstractCamelContext : Started route1 (kamelet://coffee-source) 2022-11-24 11:27:31.591 INFO 39527 --- [ main] e.camel.impl.engine.AbstractCamelContext : Started coffee-source-1 (timer://coffee) 2022-11-24 11:27:31.591 INFO 39527 --- [ main] e.camel.impl.engine.AbstractCamelContext : Apache Camel 3.18.1 (CamelJBang) started in 1s143ms (build:125ms init:819ms start:199ms JVM-uptime:2s) 2022-11-24 11:27:33.297 INFO 39527 --- [ - timer://coffee] coffee-integration.yaml:4 : {"id":3648,"uid":"712d4f54-3314-4129-844e-9915002ecbb7","blend_name":"Winter Cowboy","origin":"Lekempti, Ethiopia","variety":"Agaro","notes":"delicate, juicy, sundried tomato, fresh bread, lemonade","intensifier":"juicy"}
これは、クラスターを必要とせずに迅速なフィードバックを得ることができるため、Kamelet をプログラミングする際に役立ちます。準備ができたら、Kamelet をクラスターにアップロードし、Camel K インテグレーションで使用して、通常どおり開発を続行できます。