A 通过 Q1 发送一个请求,然后通过 Q2 监听反馈结果。 如果同时有 A1,A2...多个实例通过 Q1 发送请求,是没有问题的。 但是 A,A1,A2...同时通过 Q2 监听反馈结果,就会存在有人拿了本不属于他的反馈。 如 A 拿了 A1 的反馈,这样 A1 就拿不到反馈了。
--------- 背景如上 ----------
目前监听使用的 org.springframework.jms 的 JmsListener 以及用的 DefaultJmsListenerContainerFacotry,CachingConnectionFactory,MQQueueConnectionFactory 等常规配置。
---------- 问题-----------
如何多实例同时监听 Q2 的反馈结果,且只读取属于自己的请求反馈呢?
1
wtfedc 2023-04-07 13:59:45 +08:00
可以只 peek ,不消费其他实例的消息。或者消费之后,发现不匹配,再丢回去
|
3
fkname 2023-04-07 14:22:16 +08:00
不是有 topic 区分吗
|
4
billly 2023-04-07 14:23:58 +08:00
消息能广播吗?可以的话发现不是自己的,直接丢掉
|
5
lchqfnu OP @billly 有考虑改 topic ,但是 topic 与 queue 是有一点区别的,topic 是非持久的,如果没有监听,topic 中的消息会丢失。
|
6
superychen 2023-04-07 14:38:20 +08:00
A,A1,A2 不在一个 group 里就可以了吧,每个都能消费到
|
7
Azzsanjin 2023-04-07 15:11:25 +08:00
集群消费和广播消费问题?
|
8
lchqfnu OP 目前想到的除了 q 改 topic 以外,就是使用 mq 的 consumer 的 selector 做消息选择,暂时没有实现。
|