ActiveMQ学习 (一) JSM基本概念

一、JMS的基本构件:

1、连接工厂:ConnectionFactory是客户用来创建连接的对象

2、连接: Connection封装了客户与JMS提供者之间的一个虚拟连接

3、会话: Session是生产和消费消息的一个单线程上下文。用于创建消息生产者(producer)、生产消费者(consumer)和消息(message)等。

会话提供一个事务性的上下文,在这个上下文中,一组消息的发送和接收被组合到一个原子操作中。

4、目的地: Destination 目的地是客户用来指定其生产消息的目标和消费消息的来源的对象。

JMS目前定义两种消息传递域,可以理解为传递方式。一种是点对点(PTP)消息传递和发布/订阅消息传递

在点对点模式中,目的地被称为队列(queue),在发布/订阅模式中,目的地被称为主题(topic)

点对点(PTP)特点:

(1)每个消息只能有一个消费者

(2)消息的生产者和消费者之间没有时间上的相对性。无论消费者在生产者发送消息的时候是否处于运行状态,它都可以提取消息。

发布/订阅模式特点:

(1)每个消息可以有多个消费者。

(2)生产者和消费者之间有时间上的相关性。订阅一个主题的消费者只能消费他订阅之后生产者发布的消息

(3)JMS允许客户创建持久订阅,持久订阅允许消费者消费在他未处于激活状态时发送的消息

5、生产者: Message Procedur   消息生产者是由会话创建的一个对象,用于把消息发送到一个目的地。

6、消费者: Message Consumer 消息消费者也是由会话创建的对象,用于接收目的地的消息。

消息的消费有两种方法:

(1)同步消费,通过调用消费者的receive方法从目的地显示的提取消息。receive方法可以一直阻塞,直到有消息到达。

(2)异步消费,客户可以为消费者注册一个消息监听器来定义在消息到达的时候采取什么行动

7、消息: massage  消息由三部分组成:

(1)消息头,每个消息头字段都有相应的getter和setter方法

(2)消息属性,如果需要消除消息头字段意外的值,那么可以使用消息属性

(3)消息体,也就是消息内容

消息类型有:TestMessage,MapMessage,BytesMessage,StreamMessage,ObjectMessage

二、消息确认

只有在被确认后才认为已经被成功消费。消息的成功消费通常包含三个阶段:

客户接收消息,客户处理消息,消息被确认。

在事务性会话中,当一个事物被提交的时候,确认自动发生。在非事务性会话中,消息何时被确认取决于创建会话时的应答模式。

(1)Session.AUTO_ACKNOWLEDGE  当客户成功从receive方法返回的时候,或者从MessageListener.onMessage方法成功返回的时候

会话自动确认客户收到的消息

(2)Session.CLIENT_ACKNOWLEDGE 客户通过消息的acknowledge方法确认消息。需要注意:在这种模式下确认是在会话层上进行的

确认一个被消费的消息讲自动确认所有已被会话消费的消息。例:消费者A消费了10个消息,然后确认第5个消息,那么所有的消

息10个都被确认

(3)Session.DUPS_ACKNOWLEDGE 该选择只是会话迟钝的确认消息提交,如果Provider失败,那么可能会导致一些重复的消息,如果

消息重复,那么Provider必须把消息头的JMSRedelivered字段设置为true.


三、消息持久性

JMS支持两种消息提交模式:

PERSISTENT。指示JMS Provider持久保存消息,以保证消息不会因为JMS Provider的失败而丢失。

NON_PERSISTENT。不要求JMS Provider持久保存消息

四、消息优先级

优先级  可以使用消息优先级来指示JMS Provider首先提交紧急的消息。优先级分10个级别,从0(最低)到9(最高)

如果不指定优先级,默认级别是4。需要注意的是,JMS Provider并不一定保证按照优先级的顺序提交消息。

五、消息过期

可以设置消息在一定时间后过期,默认是永不过期

六、临时目的地

可以通过会话上的createTemporaryQueue方法和createTemporaryTopic方法来创建临时目的地,它们的存在时间只限于创建它们的连接所保持的时间

只有创建该临时目的地的连接上的消息消费者才能够从临时目的地中提取消息

七、持久订阅

首先消息生产者必须使用PERSISTENT提交消息。客户可以通过会话上的createDurableSubscriber(Topic var1, String var2)

方法的第一个参数必须是一个topic,第二个参数是订阅的名称。

JMS Provider会存储发布到持久订阅对应的topic上的消息如果最初创建持久订阅的客户或者任何其它客户使用相同的连接工厂和连接的客户ID、

相同的主题和相同的订阅名再次调用会话上的createDurableSubscriber方法,那么该持久订阅会被激活

JMS Provider会客户发送客户处于非激活状态时所发布的消息。 持久订阅在某个时刻只能有一个激活的订阅者。

持久订阅在创建之后会一直保留,直到应用程序调用会话上的unsubscribe方法。

八、本地事物

在一个JMS客户端,可以使用本地事务来组合消息的发送和接收。

JMS Session接口提供了commit和rollback方法。事务提交意味着生产的所有消息被发送,消费的所有消息被确认

事务回滚意味着生产的所有消息被销毁,消费的所有消息被恢复并重新提交,除非它们已经过期

 事务性的会话总是牵涉到事务处理中,commit或rollback方法一旦被调用,一个事务就结束了,而另一个事务被开始。关闭事务性会话将回滚其中的事务

注意:

(1)如果使用请求/回复机制,即发送一个消息,同时希望在同一个事务中等待接收该消息的回复,那么程序将被挂起,因为知道事务提交,发送操作才会真正执行。 

(2)消息的生产和消费不能包含在同一个事务中



JMS 公共 点对点域  发布/订阅域
ConnectionFactory(消息工厂) QueueConnectionFactory TopicConnectionFactory
Connection(连接) QueueConnection TopicConnection
Destination(目的地) Queue Topic
Session(会话) QueueSession TopicSession
MessageProducer(消息生产者) QueueSender TopicPublisher
MessageConsumer(消息消费者) QueueReceiver TopicSubscriber


猜你喜欢

转载自blog.csdn.net/u010994966/article/details/77895374
今日推荐