Coder Social home page Coder Social logo

camel-demo's Introduction

Spring Boot Camel Demo

Synposis

The purpose of this small project is to show the following:

  • Camel usage with Spring Boot
  • Publishing messages to queues (Azure ServiceBus, SQS & Kafka)
  • Consuming messages from queues (Azure ServiceBus, SQS & Kafka)
  • Spring/JUnit test integration with Camel

Multiple scenarios are demonstrated, you just need to uncomment the relevant "from" and "to" endpoint names in application.yml

Prerequisites

  • AWS account access
  • AWS SQS queue ARN
  • Kafka broker available (see docker compose further down)
  • Azure ServiceBus Topic access

Setting up

  • Set the following environment variables in the environment for AWS

    • AWS_KEY
    • AWS_SECRET
  • Set the following environment variables in the environment for Azure ServiceBus (uses Stacks project topics)

    • SB_ENABLED
    • SB_CONNECTION_STRING
    • SB_SUBSCRIPTION
    • SB_TOPIC

Starting the app

mvn clean spring-boot:run

Pushing Messages onto the queue

curl -H "Content-Type: application/json" localhost:8080/message/send -d '{"name":"steve"}'

Kafka Docker compose

The included docker compose can be used for this example.

Execute the commands:

docker network create amido

docker compose -f docker-compose.yml up -d

Example Scenarios

The easiest way to exercise the app is to enable in properties (application.yml) one of the following scenarios:

  • Scenario 1 : SQS Queue
  • Scenario 2 : SNS Topic to SQS Queue
  • Scenario 3 : Kafka Topic
  • Scenario 4 : Azure ServiceBus

camel-demo's People

Contributors

sdavis-amido avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.