Add sample for multiple input/output channels in an app
- This resolves #12
This commit is contained in:
40
multi-io/README.md
Normal file
40
multi-io/README.md
Normal file
@@ -0,0 +1,40 @@
|
||||
Spring Cloud Stream Stream Listener Sample
|
||||
=============================
|
||||
|
||||
In this *Spring Cloud Stream* sample, the application shows how to use configure multiple input/output channels inside
|
||||
a single application.
|
||||
|
||||
## Requirements
|
||||
|
||||
To run this sample, you will need to have installed:
|
||||
|
||||
* Java 8 or Above
|
||||
|
||||
This example requires Redis to be running on localhost.
|
||||
|
||||
## Code Tour
|
||||
|
||||
This sample is a Spring Boot application that bundles multiple application together to showcase how to configure
|
||||
multiple input/output channels.
|
||||
|
||||
* MultipleIOChannelsApplication - the Spring Boot Main Application
|
||||
* SampleSource - the app that configures two output channels (output1 and output2).
|
||||
* SampleSink - the app that configures two input channels (input1 and input2).
|
||||
|
||||
The channels output1 and input1 connect to the same destination (test1) on the broker (Redis) and the channels output2 and
|
||||
input2 connect to the same destination (test2) on redis.
|
||||
For demo purpose, the apps `SampleSource` and `SampleSink` are bundled together. In practice they are separate applications
|
||||
unless bundled together by the `AggregateApplicationBuilder`.
|
||||
|
||||
## Building with Maven
|
||||
|
||||
Build the sample by executing:
|
||||
|
||||
>$ mvn clean package
|
||||
|
||||
## Running the Sample
|
||||
|
||||
To start the source module execute the following:
|
||||
|
||||
>$ java -jar target/spring-cloud-stream-sample-multi-io-1.0.0.BUILD-SNAPSHOT-exec.jar
|
||||
|
||||
59
multi-io/pom.xml
Normal file
59
multi-io/pom.xml
Normal file
@@ -0,0 +1,59 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<artifactId>spring-cloud-stream-sample-multi-io</artifactId>
|
||||
<packaging>jar</packaging>
|
||||
|
||||
<name>spring-cloud-stream-sample-multi-io</name>
|
||||
<description>Demo project for multiple input/output channels binding</description>
|
||||
|
||||
<parent>
|
||||
<groupId>org.springframework.cloud</groupId>
|
||||
<artifactId>spring-cloud-stream-samples</artifactId>
|
||||
<version>1.0.0.BUILD-SNAPSHOT</version>
|
||||
</parent>
|
||||
|
||||
<properties>
|
||||
<start-class>demo.MultipleIOChannelsApplication</start-class>
|
||||
</properties>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>org.springframework.cloud</groupId>
|
||||
<artifactId>spring-cloud-stream</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.springframework.cloud</groupId>
|
||||
<artifactId>spring-cloud-stream-binder-redis</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-starter-redis</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-configuration-processor</artifactId>
|
||||
<optional>true</optional>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-starter-test</artifactId>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
|
||||
<build>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-maven-plugin</artifactId>
|
||||
<configuration>
|
||||
<classifier>exec</classifier>
|
||||
</configuration>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
|
||||
</project>
|
||||
@@ -0,0 +1,29 @@
|
||||
/*
|
||||
* Copyright 2015 the original author or authors.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package demo;
|
||||
|
||||
import org.springframework.boot.SpringApplication;
|
||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||
|
||||
@SpringBootApplication
|
||||
public class MultipleIOChannelsApplication {
|
||||
|
||||
public static void main(String[] args) {
|
||||
SpringApplication.run(MultipleIOChannelsApplication.class, args);
|
||||
}
|
||||
|
||||
}
|
||||
57
multi-io/src/main/java/demo/SampleSink.java
Normal file
57
multi-io/src/main/java/demo/SampleSink.java
Normal file
@@ -0,0 +1,57 @@
|
||||
/*
|
||||
* Copyright 2015 the original author or authors.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package demo;
|
||||
|
||||
import org.springframework.cloud.stream.annotation.EnableBinding;
|
||||
import org.springframework.cloud.stream.annotation.Input;
|
||||
import org.springframework.cloud.stream.annotation.StreamListener;
|
||||
import org.springframework.messaging.SubscribableChannel;
|
||||
|
||||
/**
|
||||
* @author Ilayaperumal Gopinathan
|
||||
*/
|
||||
@EnableBinding(SampleSink.MultiInputSink.class)
|
||||
public class SampleSink {
|
||||
|
||||
@StreamListener(MultiInputSink.INPUT1)
|
||||
public synchronized void receive1(String message) {
|
||||
System.out.println("******************");
|
||||
System.out.println("At Sink1");
|
||||
System.out.println("******************");
|
||||
System.out.println("Received message " + message);
|
||||
}
|
||||
|
||||
@StreamListener(MultiInputSink.INPUT2)
|
||||
public synchronized void receive2(String message) {
|
||||
System.out.println("******************");
|
||||
System.out.println("At Sink2");
|
||||
System.out.println("******************");
|
||||
System.out.println("Received message " + message);
|
||||
}
|
||||
|
||||
public interface MultiInputSink {
|
||||
String INPUT1 = "input1";
|
||||
|
||||
String INPUT2 = "input2";
|
||||
|
||||
@Input(INPUT1)
|
||||
SubscribableChannel input1();
|
||||
|
||||
@Input(INPUT2)
|
||||
SubscribableChannel input2();
|
||||
}
|
||||
}
|
||||
76
multi-io/src/main/java/demo/SampleSource.java
Normal file
76
multi-io/src/main/java/demo/SampleSource.java
Normal file
@@ -0,0 +1,76 @@
|
||||
/*
|
||||
* Copyright 2016 the original author or authors.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package demo;
|
||||
|
||||
import org.springframework.cloud.stream.annotation.EnableBinding;
|
||||
import org.springframework.cloud.stream.annotation.Output;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.integration.annotation.InboundChannelAdapter;
|
||||
import org.springframework.integration.annotation.Poller;
|
||||
import org.springframework.integration.core.MessageSource;
|
||||
import org.springframework.messaging.Message;
|
||||
import org.springframework.messaging.MessageChannel;
|
||||
import org.springframework.messaging.support.GenericMessage;
|
||||
|
||||
/**
|
||||
* @author Ilayaperumal Gopinathan
|
||||
*/
|
||||
@EnableBinding(SampleSource.MultiOutputSource.class)
|
||||
public class SampleSource {
|
||||
|
||||
@Bean
|
||||
@InboundChannelAdapter(value = MultiOutputSource.OUTPUT1, poller = @Poller(fixedDelay = "1000", maxMessagesPerPoll = "1"))
|
||||
public synchronized MessageSource<String> messageSource1() {
|
||||
return new MessageSource<String>() {
|
||||
public Message<String> receive() {
|
||||
String message = "FromSource1";
|
||||
System.out.println("******************");
|
||||
System.out.println("From Source1");
|
||||
System.out.println("******************");
|
||||
System.out.println("Sending value: " + message);
|
||||
return new GenericMessage(message);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
@Bean
|
||||
@InboundChannelAdapter(value = MultiOutputSource.OUTPUT2, poller = @Poller(fixedDelay = "1000", maxMessagesPerPoll = "1"))
|
||||
public synchronized MessageSource<String> timerMessageSource() {
|
||||
return new MessageSource<String>() {
|
||||
public Message<String> receive() {
|
||||
String message = "FromSource2";
|
||||
System.out.println("******************");
|
||||
System.out.println("From Source2");
|
||||
System.out.println("******************");
|
||||
System.out.println("Sending value: " + message);
|
||||
return new GenericMessage(message);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
public interface MultiOutputSource {
|
||||
String OUTPUT1 = "output1";
|
||||
|
||||
String OUTPUT2 = "output2";
|
||||
|
||||
@Output(OUTPUT1)
|
||||
MessageChannel output1();
|
||||
|
||||
@Output(OUTPUT2)
|
||||
MessageChannel output2();
|
||||
}
|
||||
}
|
||||
14
multi-io/src/main/resources/application.yml
Normal file
14
multi-io/src/main/resources/application.yml
Normal file
@@ -0,0 +1,14 @@
|
||||
server:
|
||||
port: 8082
|
||||
spring:
|
||||
cloud:
|
||||
stream:
|
||||
bindings:
|
||||
output1:
|
||||
destination: test1
|
||||
output2:
|
||||
destination: test2
|
||||
input1:
|
||||
destination: test1
|
||||
input2:
|
||||
destination: test2
|
||||
36
multi-io/src/test/java/demo/ModuleApplicationTests.java
Normal file
36
multi-io/src/test/java/demo/ModuleApplicationTests.java
Normal file
@@ -0,0 +1,36 @@
|
||||
/*
|
||||
* Copyright 2015 the original author or authors.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package demo;
|
||||
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.springframework.test.annotation.DirtiesContext;
|
||||
import org.springframework.test.context.web.WebAppConfiguration;
|
||||
import org.springframework.boot.test.SpringApplicationConfiguration;
|
||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
||||
|
||||
@RunWith(SpringJUnit4ClassRunner.class)
|
||||
@SpringApplicationConfiguration(classes = MultipleIOChannelsApplication.class)
|
||||
@WebAppConfiguration
|
||||
@DirtiesContext
|
||||
public class ModuleApplicationTests {
|
||||
|
||||
@Test
|
||||
public void contextLoads() {
|
||||
}
|
||||
|
||||
}
|
||||
2
pom.xml
2
pom.xml
@@ -1,7 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<artifactId>spring-cloud-stream-samples</artifactId>
|
||||
<packaging>pom</packaging>
|
||||
<url>https://github.com/spring-cloud/spring-cloud-stream-samples</url>
|
||||
@@ -26,6 +25,7 @@
|
||||
<module>multibinder</module>
|
||||
<module>multibinder-differentsystems</module>
|
||||
<module>rxjava-processor</module>
|
||||
<module>multi-io</module>
|
||||
</modules>
|
||||
<dependencyManagement>
|
||||
<dependencies>
|
||||
|
||||
Reference in New Issue
Block a user