JMS和消息驱动Bean(MDB)
1.Java消息服务(JMS)编程:
应用程序A发送一条消息到消息服务器的某个目的地,然后消息服务器把消息转发给应用程序B,由于JMS允许消息发送方和接收方不同时在线,没有代码关联,从而实现应用程序的解耦,JMS的过程如下:
应用程序A——>消息——>JMS消息服务器——>消息——>应用程序B
2.JMS消息的传递模型:
JMS支持两种消息传递模型:点对点(PTP)、发布订阅(pub/sub)。
(1).PTP:
一条消息只能传递给一个接收方,采用javax.jms.Queue表示。
每个消息被发送到一个特定的消息队列中,接收者从消息队列中获取消息,队列保留着消息直到消息被消费或者超时,当发送时如果接收方不在线,则当接收方上线时还可以接收到消息。
发送者和接收者之间在时间上没有依赖性,即当发送者发送了消息之后,不管接收者是否在运行,都不会影响消息被发送到消息队列,接收者在成功接收消息之后需要向队列应答成功,若希望发送的每条消息都应该被成功接收处理的话,应该使用PTP方式。
(2).pub/sub:
一条消息可以传递给多个接收方,采用javax.jms.Topic表示。
每条消息可以有多个接收者,发布者和订阅者有时间
JMS与MDB实例
最新推荐文章于 2020-06-18 18:05:52 发布
本文介绍了Java消息服务(JMS)的概念,包括点对点(PTP)和发布订阅(pub/sub)两种消息传递模型,并详细阐述了JMS消息的组成部分。通过JMS与MDB的实例,展示了如何配置消息目标地址,以及producer和consumer的操作流程。
摘要由CSDN通过智能技术生成