如何解决Spring Cloud Stream Function支持不起作用
我试图将Spring Cloud Stream与本topic中所述的功能一起使用。但这不起作用。
我的功能:
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class);
}
@Bean
public Consumer<String> consumer() {
return s -> System.out.println(s);
}
}
然后我推送消息。通过使用consumer-in-0
批注制作的生产者进入@Output
频道:
pulic interface Source {
@Output("source")
MessageChannel producer();
}
source.producer().send(MessageBuilder.withPayload("Hello").build());
我的Yaml频道配置:
spring:
cloud:
function:
definition: consumer
stream:
bindings:
source:
destination: consumer-in-0
如果我通过@Input
配置使用消费者-一切正常。
同样在rabbitmq管理器中,我看到生产者正在工作并发送消息,但是消费者没有使用它们。
请帮助我。
P.S。我也使用Spring WebFlux
解决方法
不能在同一应用程序中混合使用EnableBinding
和功能模型。如果将生产者和使用者都放在同一个应用程序中,则可能要使用Supplier
转换生产者。例如
@Bean
public Supplier<String> supplier() {
return () -> MessageBuilder.withPayload("Hello").build();
}
然后
spring:
cloud:
function:
definition: supplier;consumer
stream:
bindings:
supplier-out-0:
destination: consumer-in-0
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。