Files
spring-cloud-stream-samples/processor-samples/reactive-processor-kafka

Spring Cloud Stream Reactive Processor Basic Sample
==================================================

This is a Spring Cloud Stream reactive processor sample.

## Requirements

To run this sample, you will need to have installed:

* Java 8 or Above

## Running the application

The following instructions assume that you are running Kafka as a Docker image.

* Go to the application root (not the repository root, but this application)
* `docker-compose up -d`

* `./mvnw clean package`

* `java -jar target/reactive-processor-0.0.1-SNAPSHOT-kafka.jar`

The main application contains the reactive processor that receives textual data for a duration and aggregates them.
It then sends the aggregated data through the outbound destination of the processor.

The application also provides a source and sink for testing.
Test source will generate some text every second and the test sink will verify that the processor has accumulated the text over a duration.
Test source is bound to the same broker destination where the processor is listening from.
Similarly test sink is bound to the same broker destination where the processor is producing to.

You will see output similar to the following on the console every 5 seconds.

```
Data received: foobarfoobarfoo
Data received: barfoobarfoobar
Data received: foobarfoobarfoo
Data received: foobarfoobarfoo
```

* `docker-compose down`

## Running the application using Rabbit binder

All the instructions above apply here also, but instead of running the default `docker-compose.yml`, use the command below to start a Rabbitmq cluser.

* `docker-compose -f docker-compose-rabbit.yml up -d`

* `./mvnw clean package -P rabbit-binder`

* `java -jar target/reactive-processor-0.0.1-SNAPSHOT-rabbit.jar`

Once you are done testing: `docker-compose -f docker-compose-rabbit.yml down`