关于监听 MQ 队列消息的判定问题

2023-04-07 13:36:38 +08:00
 lchqfnu

A 通过 Q1 发送一个请求,然后通过 Q2 监听反馈结果。 如果同时有 A1,A2...多个实例通过 Q1 发送请求,是没有问题的。 但是 A,A1,A2...同时通过 Q2 监听反馈结果,就会存在有人拿了本不属于他的反馈。 如 A 拿了 A1 的反馈,这样 A1 就拿不到反馈了。

--------- 背景如上 ----------

目前监听使用的 org.springframework.jms 的 JmsListener 以及用的 DefaultJmsListenerContainerFacotry,CachingConnectionFactory,MQQueueConnectionFactory 等常规配置。

---------- 问题-----------

如何多实例同时监听 Q2 的反馈结果,且只读取属于自己的请求反馈呢?

1575 次点击
所在节点    Java
9 条回复
wtfedc
2023-04-07 13:59:45 +08:00
可以只 peek ,不消费其他实例的消息。或者消费之后,发现不匹配,再丢回去
lchqfnu
2023-04-07 14:10:23 +08:00
@wtfedc IBM MQ ,好像没有 peek 的操作方式。消费之后发现不匹配再丢回去,有概率还会被错取。
fkname
2023-04-07 14:22:16 +08:00
不是有 topic 区分吗
billly
2023-04-07 14:23:58 +08:00
消息能广播吗?可以的话发现不是自己的,直接丢掉
lchqfnu
2023-04-07 14:33:14 +08:00
@billly 有考虑改 topic ,但是 topic 与 queue 是有一点区别的,topic 是非持久的,如果没有监听,topic 中的消息会丢失。
superychen
2023-04-07 14:38:20 +08:00
A,A1,A2 不在一个 group 里就可以了吧,每个都能消费到
Azzsanjin
2023-04-07 15:11:25 +08:00
集群消费和广播消费问题?
lchqfnu
2023-04-07 15:13:12 +08:00
目前想到的除了 q 改 topic 以外,就是使用 mq 的 consumer 的 selector 做消息选择,暂时没有实现。
lchqfnu
2023-04-07 20:16:28 +08:00
@Azzsanjin 是的。试过 mq messageconsumer 的 selector 不行,那个只能通过消息头的属性判定。关于 topic ,好像跟 queue 差异很大啊? topic 有名称还有字符串,搞不清楚怎么用 jms 来监听

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/930549

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX