JMS和消息驱动Bean
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表示。
每条消息可以有多个接收者,发布者和订阅者有时间上的依赖性,针对某个主题的订阅者必须创建一个订阅之后才能消费发布者发布的消息,而且为了接收消息,订阅者必须保持运行。发布订阅模式的消息不支持离线消息,即当发生消息时,接收方如果不在线,当接收再次上线时就无法接收到已经发送过的消息。