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