初识JMS

1.介绍

MOM即面向消息的中间件,使用消息传送提供者来协助消息传输操作。MOM需要提供API与管理工具。客户端调用API,把消息发送到提供者指定的目的地中。在消息发送之后,客户端会执行其他的工作,并且在接收方收到消息之前,提供者一直会保留该消息。

JMS即JAVA消息服务(Java Message Service)应用程序接口,是一个JAVA平台中面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送消息,进行异步通信。Java消息服务是一个与平台无关的API,绝大多数MOM提供商都对JMS提供支持。

 

2.JMS domains(消息传递域)

1)P2P(点对点)

    每个消息只能有一个消费者。

    消息的生产者与消费者之间没有时间上的相关性。只要生产者发送了消息,消费者随时都可以提取。

2)发布订阅publish/subscribe

    每个消息可以有多个消费者。

    消息的生产者与消费者之间存在时间上的相关性,订阅一个主题的消费者只能消费订阅主题发布的消息。JMS规范允许客户端创建持久订阅

  3.JMS API

        ConnectionFactory   连接工厂

 

        Connection              封装客户端与JMS provider 之间的一个虚拟连接

        Session                   生产和消费消息的一个单线程上下文;用于创建producer、consumer/message、queue、topic...

        Destination             消息发送或消息接受的目的地

        MessageProducer/consumer    消息生产者/消费者

4.Message(消息体)

TextMessage/MapMessage/BytesMessage/StreamMessage(输入输出流)/ObjectMessage(可序列化对象

5.JMS的可靠性机制

JMS消息之后被确认后,才会认为是被成功消费。消息的消费包含三个阶段: 客户端接收消息、客户端处理消息、消息被确认

事务性会话

 如上图,设置为true的时候,消息会在session.commit以后自动签收

非事务性会话

 

在该模式下,消息何时被确认取决于创建会话时的应答模式

AUTO_ACKNOWLEDGE

当客户端成功从recive方法返回以后,或者[MessageListener.onMessage](消息监听器) 方法成功返回以后,会话会自动确认该消息

CLIENT_ACKNOWLEDGE

客户端通过调用消息的textMessage.acknowledge();确认消息。

在这种模式中,如果一个消息消费者消费一共是10个消息,那么消费了5个消息,然后在第5个消息通过textMessage.acknowledge(),那么之前的所有消息都会被消确认

DUPS_OK_ACKNOWLEDGE

延迟确认

 

本地事务

在一个JMS客户端,可以使用本地事务来组合消息的发送和接收。JMS Session 接口提供了commitrollback方法。

JMS Provider会缓存每个生产者当前生产的所有消息,直到commit或者rollback,commit操作将会导致事务中所有的消息被持久存储;rollback意味着JMS Provider将会清除此事务下所有的消息记录。在事务未提交之前,消息是不会被持久化存储的,也不会被消费者消费。

事务提交意味着生产的所有消息都被发送。消费的所有消息都被确认;

事务回滚意味着生产的所有消息被销毁,消费的所有消息被恢复,也就是下次仍然能够接收到发送端的消息,除非消息已经过期了

JMS (pub/sub)模型

1. 订阅可以分为非持久订阅和持久订阅

2. 当所有的消息必须接收的时候,则需要用到持久订阅。反之,则用非持久订阅

JMS  (P2P)模型

1. 如果session关闭时,有一些消息已经收到,但还没有被签收,那么当消费者下次连接到相同的队列时,消息还会被签收

2. 如果用户在receive方法中设定了消息选择条件,那么不符合条件的消息会留在队列中不会被接收

3. 队列可以长久保存消息直到消息被消费者签收。消费者不需要担心因为消息丢失而时刻与jms provider保持连接状态

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值