ActiveMQ (二):JMS
1.前言
由于ActiveMQ是一种完全符合JMS规范的一种通信工具,所以在使用ActiveMQ前认识JMS规范就变的十分必要了。
认识JMS主要从以下方面:
a. JMS 模型
b. JMS 对象模型
c. JMS 传递方式
d. JMS 消息类型<消息正文格式>
2. 模型
Java消息服务应用程序结构支持两种模型:
点对点或队列模型
这种模型的特殊之处在于:生产者不会指定唯一的消费者消费消息,而是多个消费者消费一个消息,即多个消费者都可以消费这条消息,且只有一个消费者可以消费到。
发布者/订阅者模型
这种模型是使用发布/订阅者模式,订阅者保存Topic地址,从地址中“拉取”消息数据。
3. 对象模型
ActiveMQ 依赖下面的模型进行消息发送接收。
模型图如下:
JMS对象模型包含如下几个要素:
4.传递方式
JMS有两种传递消息的方式:
NON_PERSISTENT(非持久化):消息最多投递一次。若消费者服务未启动,则在消息发送后再启动消费者服务,消费者无法获取到之前发送的消息。
PERSISTENT(持久化):使用暂存后再转送的机理投递。消费者在消息发送后启动服务,可以接收到之前发送的消息。
5. JMS消息类型
MS定义了五种不同的消息正文格式,以及调用的消息类型:
参考资料:
1. http://baike.baidu.com/item/JMS/2836691?sefr=enterbtn#5
2. http://shmilyaw-hotmail-com.iteye.com/blog/1897635