【发布时间】:2019-06-04 18:19:34
【问题描述】:
我将 Spring Cloud Stream 与 Spring Boot 一起使用。我的申请很简单:
ExampleService.class:
@EnableBinding(Processor1.class)
@Service
public class ExampleService {
@StreamListener(Processor1.INPUT)
@SendTo(Processor1.OUTPUT)
public String dequeue(String message){
System.out.println("New message: " + message);
return message;
}
@SendTo(Processor1.OUTPUT)
public String queue(String message){
return message;
}
}
处理器1.class:
public interface Processor1 {
String INPUT = "input1";
String OUTPUT = "output1";
@Input(Processor1.INPUT)
SubscribableChannel input1();
@Output(Processor1.OUTPUT)
MessageChannel output1();
}
application.properties:
spring.cloud.stream.bindings.input1.destination=test_input
spring.cloud.stream.bindings.input1.group=test_group
spring.cloud.stream.bindings.input1.binder=binder1
spring.cloud.stream.bindings.output1.destination=test_output
spring.cloud.stream.bindings.output1.binder=binder1
spring.cloud.stream.binders.binder1.type=rabbit
spring.cloud.stream.binders.binder1.environment.spring.rabbitmq.host=localhost
场景:
1) 当我在“test_input.test_group”队列中推送消息时,消息被正确打印并正确发送到“test_output”交换。所以 ExampleService::dequeue 效果很好。
2) 当我调用 ExampleService::queue 方法时(从类外部,在测试中),消息永远不会发送到“test_output”交换。
我正在使用 Spring Boot 2.0.6.RELEASE 和 Spring Cloud Stream 2.0.2.RELEASE。
任何人都知道为什么方案 2) 不起作用?提前致谢。
【问题讨论】:
-
我也有同样的问题
标签: spring spring-boot spring-cloud spring-cloud-stream