This project contains the various examples for working with Apache Camel Spring Boot. The examples can be run using Maven. When using the Maven command, Maven will attempt to download the required dependencies from a central repository to your local repository. View the individual example READMEs for details.
Master branch should only be used for development purposes, which will be pointing to the SNAPSHOT version of the next release.
To execute the examples, checkout into the tag for the latest release. For example:
$ git checkout tags/camel-spring-boot-examples-3.5.0
Then, install the root pom:
$ mvn install
After that, you should be able to execute the examples following each example’s readme’s instructions.
Number of Examples: 61 (0 deprecated)
Example | Category | Description |
---|---|---|
Spring Boot Jta Jpa Autoconfigure (spring-boot-jta-jpa-autoconfigure) |
Advanced |
An example showing JTA with Spring Boot Autoconfiguration |
Spring Boot Jta Jpa Xml (spring-boot-jta-jpa-xml) |
Advanced |
An example showing JTA with Spring Boot using Spring XML configuration |
Webhook (webhook) |
Advanced |
Example on how to use the Camel Webhook component |
Endpointdsl (endpointdsl) |
Beginner |
Using type-safe Endpoint DSL |
Jira (jira) |
Beginner |
An example that uses Jira Camel API |
Kamelet Chucknorris (kamelet-chucknorris) |
Beginner |
How easy it is to create your own Kamelets |
Load Balancer Eip (load-balancer-eip) |
Beginner |
An example showing Load Balancer EIP with Camel and Spring Boot |
Pojo (pojo) |
Beginner |
An example showing how to work with Camel POJO routing with Spring Boot |
Quartz (quartz) |
Beginner |
An example showing how to work with Camel Quartz and Camel Log with Spring Boot |
REST OpenApi (rest-openapi-simple) |
Beginner |
This example shows how to call a Rest service defined using OpenApi specification |
Spring Boot Route Reload (route-reload) |
Beginner |
Live reload of routes if file is updated and saved |
Routes Configuration (routes-configuration) |
Beginner |
Example with global routes configuration for error handling |
Routetemplate (routetemplate) |
Beginner |
How to use route templates (parameterized routes) |
Routetemplate Xml (routetemplate-xml) |
Beginner |
How to use route templates (parameterized routes) in XML |
Splitter Eip (splitter-eip) |
Beginner |
An example showing Splitter EIP with Camel and Spring Boot |
Spring Boot (spring-boot) |
Beginner |
An example showing how to work with Camel and Spring Boot |
Spring Jdbc (spring-jdbc) |
Beginner |
Camel transacted routes integrating local Spring Transaction |
Tomcat Jdbc (tomcat-jdbc) |
Beginner |
An example showing how to deploy a Camel Spring Boot application in Tomcat using its JDBC Data Source |
Type Converter (type-converter) |
Beginner |
An example showing how to create custom type converter with Camel and Spring Boot |
Spring Boot XML (xml) |
Beginner |
An example showing how to work with Camel routes in XML files and Spring Boot |
Spring Boot XML Import (xml-import) |
Beginner |
An example showing how to work with Spring XML files imported with embedded CamelContext |
Aws2 S3 (aws2-s3) |
Cloud |
An example showing the Camel AWS2 S3 component with Spring Boot |
Spring Boot Azure Eventhubs (camel-example-spring-boot-azure-eventhubs) |
Cloud |
An example showing how to work with Camel, Azure Event Hubs and Spring Boot |
Spring Boot Azure Servicebus (camel-example-spring-boot-azure-servicebus) |
Cloud |
An example showing how to work with Camel, Azure Service Bus and Spring Boot |
Infinispan (infinispan) |
Cloud |
An example showing the Camel Infinispan component with Spring Boot |
Spring Boot ServiceCall (servicecall) |
Cloud |
An example showing how to work with Camel ServiceCall EIP and Spring Boot |
Master (master) |
Clustering |
An example showing how to work with Camel’s Master component and Spring Boot |
Rest Cxf Opentelemetry (rest-cxf-opentelemetry) |
CXF |
An example showing Camel REST using CXF and OpenTelemetry with Spring Boot |
Soap Cxf (soap-cxf) |
CXF |
An example showing the Camel SOAP CXF |
Arangodb (arangodb) |
Database |
An example showing the Camel ArangoDb component with Spring Boot |
Multi Datasource 2pc (multi-datasource-2pc) |
Database |
An example showing how to work with Camel and Spring Boot using multiple pooled datasources with two-phase commit |
Resilience4j (resilience4j) |
EIP |
An example showing how to use Resilience4j EIP as circuit breaker in Camel routes |
Saga (saga) |
EIP |
This example shows how to work with a simple Apache Camel application using Spring Boot and Narayana LRA Coordinator to manage distributed actions implementing SAGA pattern |
Fhir (fhir) |
Health Care |
An example showing how to work with Camel, FHIR and Spring Boot |
Fhir Auth Tx (fhir-auth-tx) |
Health Care |
An example showing how to work with Camel, FHIR Authorization, FHIR Transaction and Spring Boot |
Health Checks (health-checks) |
Health Care |
An example on how to work with health checks ib a simple Apache Camel application using Spring Boot. |
Validator Spring Boot (validator) |
Input/Output Type Contract |
An example showing how to work with declarative validation and Spring Boot |
Mail Ms Exchange Oauth2 (mail-ms-exchange-oauth2) |
An example showing how to use Camel on Spring Boot to connect with IMAP protocol and access email data for Office 365 users using OAuth2 authentication |
|
Actuator Http Metrics (actuator-http-metrics) |
Management and Monitoring |
Example on how to use Spring Boot’s Actuator endpoints to gather info like mappings or metrics |
Jolokia (jolokia) |
Management and Monitoring |
An example that uses Jolokia to monitor and to manage Camel Routes |
Metrics (metrics) |
Management and Monitoring |
An example showing how to work with Camel and Spring Boot and report metrics to Graphite |
Monitoring Micrometrics Grafana Prometheus (monitoring-micrometrics-grafana-prometheus) |
Management and Monitoring |
Example on how to use Spring Boot’s Actuator endpoints to gather info like mappings or metrics |
Micrometer Observation (observation) |
Management and Monitoring |
An example showing how to trace incoming and outgoing messages from Camel with Micrometer Observation |
OpenTelemetry (opentelemetry) |
Management and Monitoring |
An example showing how to use Camel with OpenTelemetry |
Supervising Route Controller (supervising-route-controller) |
Management and Monitoring |
An example showing how to work with Camel’s Supervising Route Controller and Spring Boot |
Activemq (activemq) |
Messaging |
An example showing how to work with Camel, ActiveMQ openwire and Spring Boot |
Amqp (amqp) |
Messaging |
An example showing how to work with Camel, ActiveMQ Amqp and Spring Boot |
Amqp Salesforce (amqp-salesforce) |
Messaging |
AMQP message sending is created as contacts in Salesforce |
Artemis (artemis) |
Messaging |
An example showing how to work with Camel, ActiveMQ Artemis and Spring Boot |
Kafka Avro (kafka-avro) |
Messaging |
An example for Kafka avro |
Kafka Offsetrepository (kafka-offsetrepository) |
Messaging |
An example for Kafka offsetrepository |
Paho Mqtt5 Shared Subscriptions (paho-mqtt5-shared-subscriptions) |
Messaging |
An example showing how to set up multiple mqtt5 consumers that use shared subscription feature of MQTT5 |
Rabbitmq (rabbitmq) |
Messaging |
An example showing how to work with Camel and RabbitMQ |
Strimzi (strimzi) |
Messaging |
Camel example which a route is defined in XML for Strimzi integration on Openshift/Kubernetes |
Widget Gadget (widget-gadget) |
Messaging |
The widget and gadget example from EIP book, running on Spring Boot |
Reactive Streams (reactive-streams) |
Reactive |
An example that shows how Camel can exchange data using reactive streams with Spring Boot reactor |
Http Ssl (http-ssl) |
Rest |
An example showing the Camel HTTP component with Spring Boot and SSL |
Openapi Contract First (openapi-contract-first) |
Rest |
Contract First OpenAPI example |
Platform Http (platform-http) |
Rest |
An example showing Camel REST DSL with platform HTTP |
Rest Openapi (rest-openapi) |
Rest |
An example showing Camel REST DSL and OpenApi with Spring Boot |
Rest Openapi Springdoc (rest-openapi-springdoc) |
Rest |
An example showing Camel REST DSL and OpenApi with a Springdoc UI in a Spring Boot application |
-
First login to your openshift or dev-sandbox and create a new project. Here $EXAMPLE is the name of the example you want to deploy:
$ oc new-project csbex-$EXAMPLE
-
Create an odo component using the devfile.yaml
$ odo create csb-ubi8 --app $EXAMPLE
-
To set the specific example you want to deploy as an env variable (SUB_FOLDER):
$ odo config set --env SUB_FOLDER=$EXAMPLE
-
Then push it to openshift cluster:
$ odo push
-
Only few examples can be deployed using devfile:
fhir-auth-tx, geocoder, health-checks, kamelet-chucknorris, load-balancer-eip, metrics, paho-mqtt5-shared-subscriptions, pojo, quartz, reactive-streams, rest-jpa, rest-openapi-springdoc, rest-openapi, rest-producer, rest-swagger, route-reload, routetemplate, splitter-eip, spring-boot, supervising-route-controller, type-converter, unit-testing, validator, xml-import and xml.
-
Please delete
.odo folder
in your repository before starting to deploy another example, so that it will delete the components related to previous example. -
If you have an internal repository, set the MAVEN_MIRROR_URL environment with your maven repo before pushing:
$ odo config set --env MAVEN_MIRROR_URL=https://my-maven-mirror/
If you hit any problem using Camel or have some feedback, then please let us know.
We also love contributors, so get involved :-)
The Camel riders!