zoukankan      html  css  js  c++  java
  • JMS消息服务

    1.什么是JMS消息服务
      JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送消息,进行异步通信。Java消息服务是一个与具体平台无关的API,绝大多数MOM提供商都对JMS提供支持。
    2.发布订阅消息传递模型
      在发布/订阅消息模型中,发布者发布一个消息,该消息通过topic传递给所有的客户端。在这种模型中,发布者和订阅者彼此不知道对方,是匿名的且可以动态发布和订阅topic。topic主要用于保存和传递消息,且会一直保存消息直到消息被传递给客户端。
      发布/订阅消息模型特性如下:

    • 一个消息可以传递给多个订阅者
    • 发布者和订阅者有时间依赖性,只有当客户端创建订阅后才能接受消息,且订阅者需一直保持活动状态以接收消息。
    • 为了缓和这样严格的时间相关性,JMS允许订阅者创建一个可持久化的订阅。这样,即使订阅者没有被激活(运行),它也能接收到发布者的消息

      点对点消息传递特性如下:

    • 每个消息只能有一个消费者
    • 消息的生产者和消费者之间没有时间上的相关性。无论消费者在生产者发送消息的时候是否处于运行状态,它都可以提取消息。
    • 在点对点消息传递域中,目的地被称为队列(queue);在发布/订阅消息传递域中,目的地被称为主题(topic)

    3.接收消息方式
      同步:使用同步方式接收消息的话,消息订阅者调用receive()方法。在receive()中,消息未到达或在到达指定时间之前,方法会阻塞,直到消息可用
      异步:使用异步方式接收消息的话,消息订阅者需注册一个消息监听者,类似于事件监听器,只要消息到达,JMS服务提供者会通过调用监听器的onMessage()递送消息。
    4.JMS对象模型
      1.连接工厂:连接工厂(ConnectionFactory)是由管理员创建,并绑定到JNDI树中。客户端使用JNDI查找连接工厂,然后利用连接工厂创建一个JMS连接。 

    ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKEURL);

      2.JMS连接:JMS连接(Connection)表示JMS客户端和服务器端之间的一个活动的连接,是由客户端通过调用连接工厂的方法建立的。

    Connection connection = connectionFactory.createConnection(); 
    connection.start();

      3.JMS会话:JMS会话(Session)表示JMS客户与JMS服务器之间的会话状态。JMS会话建立在JMS连接上,表示客户与服务器之间的一个会话线程。

    Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);

      4.JMS目的:JMS目的(Destination),又称为消息队列,是实际的消息源。在点对点中JMS目的为queue,在发布/订阅消息传递中,目的地为主题Topic。

    Destination destination = session.createTopic("AWSTEST.JAVA");

      5.JMS生产者和消费者:生产者(Message Producer)和消费者(Message Consumer)对象由Session对象创建,用于发送和接收消息。
      6.JMS消息类型:点对点模型,发布/订阅消息模型。
      7.消息监听器:如果注册了消息监听器,一旦消息到达,将自动调用监听器的onMessage方法。EJB中的MDB(Message-Driven Bean)就是一种MessageListener。他实现了MessageListener接口,该接口包含一个onMessage方法,在该方法中需要定义消息达到后的具体动作。通过调用setMessageListener方法我们给指定消费者定义了消息监听器
    5.JMS消息结构
      消息头、消息属性、消息体
      重点→消息体,消息体中,JMS API定义了五种类型的消息格式,让我们可以以不同的形式发送和接受消息,并提供了对已有消息格式的兼容。不同的消息类型如下:
      1.javax.jms.TextMessage,表示一个文本对象。
      2.javax.jms.ObjectMessage,表示一个JAVA对象。
      3. javax.jms.BytesMessage,表示字节数据。
      4.javax.jms.StreamMessage,表示java原始值数据流。
      5. javax.jms.MapMessage,表示键值对。

    原谅我这一生不羁放纵爱自由!
  • 相关阅读:
    函数
    大对象数据LOB
    【缓冲流、转换流、序列化流】
    【字节流、字符流】
    【File类、递归】
    【缓冲流、转换流、序列化流】
    vee-validate的使用
    微信小程序第三方授权登录
    新电脑搭建vue项目步凑
    移动端300ms延迟问题和点击穿透问题
  • 原文地址:https://www.cnblogs.com/zxfjava/p/9296301.html
Copyright © 2011-2022 走看看