JMS中消息的传递类型

 时间:2024-09-23 23:22:23

1.点对点(poin隋茚粟胫t-to-point简称PTP)和发布/订阅(publish/subscribe简称pub/sub)。

<禊诬娱飑p>两种消息传递类型非常相似,但有一下区别:

PTP消息传递模型规定了一小消息只能传递个一个接收方。

Pub/sub消息传递模型允许一条消息传递给多个接收方。

每种模型都通过扩展公用基类来实现。例如:javax.jms.Queue和javax.Jms.Topic都扩展自javax.Jms.Destination类。

2.点对点消息传递

通过PTP的消息传递模型,一个应用程序可以向另一个应用程序发送消息。在此传递模型中,目标类型是队列。消息首先被传送至队列目标,然后从该对队列将消息传送至对此队列进行监听的某个消费者.

一个队列可以关联多个对垒发送方和接收方,但一条消息仅传递给一个接收方。如果多个接收方正在监听队列上的消息,JMSProvider将根据“先来者优先“的原则确定由哪个接收方接收下一条消息。如果没有接收方在监听队列,消息将保留在队列中,直至接收方链接到队列为止。这种消息传递模型是传统意义上的拉模型或轮询模型。在此类模型中,消息不是自动推送给客户端的,而是要由客户端从队列中请求获得。

3.发布/订阅消息传递

通过发送/订阅消息传递模型,应用程序能将一条消息发送给多个接收方,在此传送模型中,目标类型是主题。消息首先被传送至目标主题,然后传送至所有已订阅此主题的活动消费者。

主题目标也支持长期订阅。长期订阅表示消费者已注册了主题目标,但在消息到达目标时该消费者可以处于非活动状态。当消费者再次处于活动状态是,将会接收该消息。如果消费者均没有注册某个主题目标,该主题只保留注册了长期订阅的非活动消费者的消息。

与PTP消息模型不同,pub/sub消息模型允许多个主题订阅者接收同一条消息。JMS一直保留消息,直至所有主题订阅者都受到消息为止。Pub/sub消息传递模型基本上是一个推模型。在模型中,消息会自动广播,消费者无需通过主动请求或轮询主题的方式来获得新的消息。

文明上网合理使用手机 原神弦歌知雅意邀约任务攻略 牛肉饺子汤的做法 征信查询次数多了还能贷款吗? 原神怎么进入风龙废墟副本
热门搜索
法式家具图片 越战电影 优秀儿童画图片大全 一代宗师 电影 睡美人电影