第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 のインストール

まず、jbangcamel 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 インテグレーションで使用して、通常どおり開発を続行できます。

トップに戻る
Red Hat logoGithubredditYoutubeTwitter

詳細情報

試用、購入および販売

コミュニティー

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

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

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

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

会社概要

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

Theme

© 2025 Red Hat, Inc.