0

我正在尝试创建一个简单的微服务项目来学习使用 Axon 框架。

我已经使用以下代码通过 RabbitMQ 设置了消息传递:

@Bean
public Exchange exchange() {
    return ExchangeBuilder.fanoutExchange("Exchange").build();
}

@Bean
public Queue queue() {
    return QueueBuilder.durable("QueueA").build();
}

@Bean
public Binding binding() {
    return BindingBuilder.bind(queue()).to(exchange()).with("*").noargs();
}

@Autowired
public void configure(AmqpAdmin admin) {
    admin.declareExchange(exchange());
    admin.declareQueue(queue());
    admin.declareBinding(binding());
}

我的 application.properties 中的以下内容:

axon.amqp.exchange=Exchange

使用此配置,通过 Axon 框架发布的所有事件都将发送到 QueueA。但是现在我想让所有 EventA 事件都转到 QueueA,而所有 EventB 事件都转到 QueueB。我怎样才能做到这一点?

4

2 回答 2

3

默认情况下,Axon Framework 使用事件的包名作为 AMQP Routing Key。这意味着您可以使用模式将队列绑定到主题交换,以匹配这些路由键。有关更多信息,请参阅https://www.rabbitmq.com/tutorials/tutorial-five-java.html

您可以通过提供自定义RoutingKeyResolver(为给定 EventMessage 返回字符串的简单函数)来自定义 Axon 的行为。然后在 中配置它AMQPMessageConverter,它负责基于 Axon EventMessage 创建 AMQP 消息(反之亦然)。DefaultAMQPMessageConverter如果您对默认的 AMQP 消息格式没问题,您可以使用。

于 2018-06-13T12:37:36.643 回答
0

但是您使用的是 fanoutExchange 所以它会将事件放入所有队列 您只需创建另一个队列并与 sameExchange 和查询端绑定即可处理事件

于 2018-06-13T12:27:15.313 回答