码迷,mamicode.com
首页 > Web开发 > 详细

JSM的topic和queue的区别

时间:2017-03-12 19:19:41      阅读:186      评论:0      收藏:0      [点我收藏+]

标签:lib   bind   auto   电脑   java   listen   用户   share   cer   

JMS(Java消息服务)中,Topic实现publish和subscribe语义。一条消息被publish时,它将发到所有感兴趣的订阅者,所以零到多个 subscriber(电脑词汇中解释为“用户“)将接收到消息的一个拷贝。但是在消息代理接收到消息时,只有激活订阅的subscriber能够获得消息的一个拷贝。 

JMS Queue执行load balancer语义。一条消息仅能被一个consumer收到。如果在message发送的时候没有可用的consumer,那么它将被保存一直到能处理该message的consumer可用。如果一个consumer收到一条message后却不响应它,那么这条消息将被转到另一个consumer 那儿。一个Queue可以有很多consumer,并且在多个可用的consumer中负载均衡

Jms规范里的两种message传输方式Topic和Queue,两者的对比如下表():技术分享

 

 

确认消息的方式有如下三种

AUTO_ACKNOWLEDGE(自动通知)

CLIENT_ACKNOWLEDGE(客户端自行决定通知时机)

DUPS_OK_ACKNOWLEDGE(延时//批量通知)

如果使用的是 客户端自行决定通知时机方式,那么需要在MessageListener显式调用message.acknowledge()来通知服务器。服务器接收到通知后采取相应的操作。

 
6

JSM的topic和queue的区别

标签:lib   bind   auto   电脑   java   listen   用户   share   cer   

原文地址:http://www.cnblogs.com/douyamv/p/6538635.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!