3

我正在尝试使用事件过滤器来减少应用程序使用的主题数量,使用新版本的 spring 云流 (Chelsea.RC1) 中提供的新功能。正在创建具有正确标头的消息,但是,检查队列中消息的内容时,该消息不包含标头,仅包含带有有效负载的正文。

public void sendEnroll(EnrollCommand data) {

    //MessageChannel
    outputEnroll.send(MessageBuilder
            .withPayload(data)
                .setHeader("brand", "MASTERCARD")
                .setHeader("operation", Operation.ENROLL).build());
}

消费者

@Service
@EnableBinding(Channel.class)
public class EnrollConsumer {

@Autowired
private EnrollService service;

@StreamListener(target = Channel.INPUT_ENROLL, condition = "headers['brand']=='MASTERCARD'")
public void enrollConsumer(@Payload String command){
    System.out.println(command);
    //service.enrollment(command);
 }
}

在消费者服务中,它给出以下警告:

WARN -kafka-listener-1 o.s.c.s.b.DispatchingStreamListenerMessageHandler:62 - Cannot find a @StreamListener matching for message with id: 7baae934-7484-a7fd-91b0-ba906558bb13
4

1 回答 1

4

您必须映射您的自定义标题:

spring.cloud.stream.kafka.binder.headers = brand,operation

该信息存在于文档中。

于 2017-03-20T17:44:11.343 回答