This example demonstrates how you can use Apache Camel to integrate a Spring-Boot application running on Kubernetes or OpenShift with a remote Kie Server.
The application utilizes the Spring @ImportResource
annotation to load a Camel Context definition via a src/main/resources/spring/camel-context.xml file on the classpath.
Important
|
This quickstart can run in 2 modes: standalone on your machine and on Kubernetes / OpenShift Cluster. Quickstart requires Java 8 or Java 11 (fuse-java-openshift-jdk11-rhel8 image is used to build in Java 11).
|
The Kie Server along with the classic hellorule
example should be deployed before running the application. The example is based on the Person
and Greeting
facts. The Camel route will periodically add a Person
fact into the remote knowledge base and retrieve a Greeting
created by the rule through REST API.
To deploy the Kie server, the business automation operator is needed. Consult the Business Automation Operator Installation Guide to obtain information on how to install the operator.
Once the operator is installed, is possible to deploy the Kie Server with the hellorule
example app:
$ oc create -f KieApp.yaml
On the Decision Server image, access to the rest API is restricted to authenticated users, so the same username and password combination chosen in the KieApp.yaml file must be used in the configuration of the current this quickstart.
Note: Username and password as well as the service name of the Kie Server for the current quickstart can be set in the application.properties
file (especially when running this quickstart using the openshift-maven-plugin) or from the Openshift creation wizard when the S2I template is used.
Configuration through the application.properties file can also be useful when running the quickstart locally.
You can run this quickstart in the following modes:
-
Kubernetes / Single-node OpenShift cluster
-
Standalone on your machine
The most effective way to run this quickstart is to deploy and run the project on OpenShift.
For more details about running this quickstart on a single-node OpenShift cluster, CI/CD deployments, as well as the rest of the runtime, see the Spring Boot Runtime Guide.
Important
|
You need to run this example on Container Development Kit 3.7 or OpenShift 4.11. Both of these products have suitable Fuse images pre-installed. If you run it in an environment where those images are not preinstalled follow the steps described in Running the Quickstart on a single-node Kubernetes/OpenShift cluster without preinstalled images. |
A single-node Kubernetes/OpenShift cluster provides you with access to a cloud environment that is similar to a production environment.
If you have a single-node Kubernetes/OpenShift cluster, such as Minishift or the Red Hat Container Development Kit, installed and running, you can deploy your quickstart there.
-
Log in to your OpenShift cluster:
$ oc login -u developer -p developer
-
Create a new OpenShift project for the quickstart:
$ oc new-project MY_PROJECT_NAME
-
Change the directory to the folder that contains the extracted quickstart application (for example,
my_openshift/spring-boot-camel-drools
) :$ cd my_openshift/spring-boot-camel-drools
-
Build and deploy the project to the OpenShift cluster:
$ mvn clean -DskipTests oc:deploy -Popenshift
-
In your browser, navigate to the
MY_PROJECT_NAME
project in the OpenShift console. Wait until you can see that the pod for thespring-boot-camel-drools
has started up. -
On the project’s
Overview
page, navigate to the details page deployment of thespring-boot-camel-drool
application:https://OPENSHIFT_IP_ADDR:8443/console/project/MY_PROJECT_NAME/browse/rc/spring-boot-camel-drools-NUMBER_OF_DEPLOYMENT?tab=details
. -
Switch to tab
Logs
and then see the messages sent by Camel:13:01:41.357 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello George! 13:01:51.355 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Seamus! 13:02:01.355 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Marty! 13:02:11.354 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Marty! 13:02:21.356 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Dave! 13:02:31.363 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Dave! 13:02:41.361 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Seamus! 13:02:51.358 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Dave! 13:03:01.363 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello George! 13:03:11.359 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Marty! 13:03:21.359 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Marty! 13:03:31.359 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Marty! 13:03:41.358 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Dave!
A single-node Kubernetes/OpenShift cluster provides you with access to a cloud environment that is similar to a production environment.
If you have a single-node Kubernetes/OpenShift cluster, such as Minishift or the Red Hat Container Development Kit, installed and running, you can deploy your quickstart there.
-
Log in to your OpenShift cluster:
$ oc login -u developer -p developer
-
Create a new OpenShift project for the quickstart:
$ oc new-project MY_PROJECT_NAME
-
Configure Red Hat Container Registry authentication (if it is not configured). Follow documentation.
-
Import base images in your newly created project (MY_PROJECT_NAME):
$ oc import-image fuse-java-openshift:1.13 --from=registry.redhat.io/fuse7/fuse-java-openshift:1.13 --confirm
-
Change the directory to the folder that contains the extracted quickstart application (for example,
my_openshift/spring-boot-camel-drools
) :$ cd my_openshift/spring-boot-camel-drools
-
Build and deploy the project to the OpenShift cluster:
$ mvn clean -DskipTests oc:deploy -Popenshift -Djkube.generator.fromMode=istag -Djkube.generator.from=MY_PROJECT_NAME/fuse-java-openshift:1.13
-
In your browser, navigate to the
MY_PROJECT_NAME
project in the OpenShift console. Wait until you can see that the pod for thespring-boot-camel-drools
has started up. -
On the project’s
Overview
page, navigate to the details page deployment of thespring-boot-camel-drool
application:https://OPENSHIFT_IP_ADDR:8443/console/project/MY_PROJECT_NAME/browse/rc/spring-boot-camel-drools-NUMBER_OF_DEPLOYMENT?tab=details
. -
Switch to tab
Logs
and then see the messages sent by Camel:13:01:41.357 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello George! 13:01:51.355 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Seamus! 13:02:01.355 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Marty! 13:02:11.354 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Marty! 13:02:21.356 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Dave! 13:02:31.363 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Dave! 13:02:41.361 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Seamus! 13:02:51.358 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Dave! 13:03:01.363 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello George! 13:03:11.359 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Marty! 13:03:21.359 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Marty! 13:03:31.359 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Marty! 13:03:41.358 [Camel (camel) thread #1 - timer://testRoute] INFO test-route - Hello Dave!
To run this quickstart as a standalone project on your local machine:
-
Download the project and extract the archive on your local filesystem.
-
Build the project:
$ cd PROJECT_DIR $ mvn clean package
-
Run the service:
$ mvn spring-boot:run
-
See the messages sent by Camel.