>我有一个Spring Cloud Stream应用程序处理死信队列。
在这里,我处理转发到 DLQ 主题的记录,如下所示 -
@SpringBootApplication
@EnableBinding(Processor.class)
public class EventDrivenApplication {
public static void main(String[] args) {
SpringApplication.run(EventDrivenApplication.class, args);
}
@StreamListener(target = Processor.INPUT)
@SendTo(Processor.OUTPUT)
public Message<?> reRoute(Message<?> failed) {
Integer retries = failed.getHeaders().get("x-retries", Integer.class);
if (retries == null) {
log.info("First retry for {}", failed);
return MessageBuilder.fromMessage(failed)
.setHeader(X_RETRIES_HEADER, new Integer(1))
.setHeader(BinderHeaders.PARTITION_OVERRIDE, failed.getHeaders().get(KafkaHeaders.RECEIVED_PARTITION_ID))
.build();
} else if (retries.intValue() < 3) {
log.info("Another retry for {}", failed);
return MessageBuilder.fromMessage(failed)
.setHeader(X_RETRIES_HEADER, new Integer(retries.intValue() + 1))
.setHeader(BinderHeaders.PARTITION_OVERRIDE, failed.getHeaders().get(KafkaHeaders.RECEIVED_PARTITION_ID))
.build();
}
return null;
}
}
当我运行此应用程序时,出现以下错误 -
SpringApplication : Application run failed
java.lang.IllegalArgumentException: Cannot set a condition for methods that return a value
为什么我们不能在具有返回值的方法中编写条件语句?
如果有人帮助我解决这个问题,我将不胜感激。
请求/回复方法不支持conditions
。
使用条件时,多个侦听器可以获取相同的消息,并且它们都无法返回回复。
我想检查本可以更宽松,但事实并非如此。