JMS

在一些场景下RPC的同步方式可能不太适合业务逻辑的处理,并且这种方式在某些场景下会导致业务的紧耦合

基于异步交互模型的JMS解决了RPC产生的紧耦合问题,它提供了一个可以通过网络访问的抽象消息队列。

结构

JMS应用由以下几个部分组成:

  • A JMS provider: A messaging system that implements the JMS specification.
  • JMS clients: Java applications that send and receive messages.
  • Messages: Objects that are used to communicate information between JMS clients.
  • Administered objects: Preconfigured JMS objects that are created by an administrator for the use of JMS clients.

消息传输模型

JMS支持两种消息模型

  • point to point (queuing)

  • publish-subscribe (topic)

消息体组成

JMS应用中,一个消息由三部分组成:headerpropertiesbody

  • header(required) 消息头,必填,包含了路由信息和标识信息。
  • properties(optional) 属性,可选,由key-value对构成,可以看做是对header的扩展。
  • body(optional) 消息体,可选,包含真正要传递的数据。JMS规范定义了JMS Provider必须要支持的六种消息类型:
    • Message:没有消息正文的消息。
    • StreamMessage:包含java基础类型的流,按顺序读写。
    • MapMessage:消息体为键值对,不定义顺序。
    • TextMessage:文本消息,消息体为字符串,例如XML消息。
    • ObjectMessage:消息体为一个序列化的java对象。
    • ByteMessage:字节消息,正文为未解释的字节。

消息的生产和消费-编程模型



点对点队列API



发布-订阅API

消息的生产

  1. 使用JNDI找到ConnectionFactory对象,或者直接实例化一个ConnectionFactory,最终得到一个QueueConnectionFactory或者TopicConnectionFactory的实例,通过这个实例为生产者创建连接。

    使用JNDI查找连接工厂对象:

    Context ctx = new InitialContext();
    ConnectionFactory cf1 =(ConnectionFactory)ctx.lookup("jms / QueueConnectionFactory");
    ConnectionFactory cf2 = (ConnectionFactory) ctx.lookup("/jms/TopicConnectionFactory");

    直接实例化连接工厂:

    ConnectionFactory connFactory = new com.sun.messaging.ConnectionFactory();
  2. 使用ConnectionFactory创建连接Connection

    Connection connection = connFactory.createConnection();

    注意:调用结束后调用connection.close()关闭所有已经创建的连接。

  3. 使用Connection对象创建Session。这些Session将一组发送和接收合并到一个原子单元内,并提供事务上下文。

    Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);

    createSession()方法有两个参数:第一个表示session是否使用事务,第二个表示session在成功收到消息后自动确认。

  4. 使用JNDI查找Destination对象,或者直接实例化Destination

    客户端使用Destination对象来指定它消费的消息的来源或者它生产的消息的目标。在point to point消息传递中,DestinationQueue,在消息传递的发布/订阅模型中,为Topic

    JNDI方式:

    Destination dest = (Queue) ctx.lookup("jms/SomeQueue");

    直接实例化:

    Queue q = new com.sun.messaging.Queue("world");
  5. 通过SessionDestination创建MessageProducerMessageProducer用来发送消息。下面的代码中没有说明Destination的使用,但是每一个消息必须指定Destination

    MessageProducer producer = session.createProducer(SomeQueue OR SomeTopic);

    完成生产者创建之后,就可以使用生产者发送消息

    producer.send(message);

消息的消费

1.2.3.4 同Producer

消息的消费分为同步消费和异步消费两种。同步消费是使用receive()方法,而异步消费则使用消息监听器,MessageListner

  1. 通过SessionDestination创建MessageConsumerMessageProducer用来接收消息。

    MessageConsumer consumer = session.createConsumer(SomeQueue or SomeTopic);

    如果是一个发布/订阅模式的消费者,可以使用Session.createDurableSubscriber()创建一个持久的topic订阅者。

    Producer同样,创建之后可以使用其功能,不同的是MessageConsumer不是主动模式,而是被动模式。在启动连接之前,消息不会传递,必须先启动连接,才能接收消息。

    connection.start();
    Message msg = consumer.receive();

    consumer.receive()可传入一个long型参数来指定超时时间,单位是ms

    注意:使用receive()方法是同步消费,异步消费需要使用消息监听器。

  2. 如果需要异步通信,需要实例化MessageListener并在MessageConsumer中注册这个监听器。

    MessageListener listener = new MyListener();
    consumer.setMessageListener(listener);

    为了避免丢失消息,注册监听器后,调用连接的start()方法,当消息开始传递,JMS会自动调用监听器的onMessage()接收消息。

JMS Java消息服务(Java Message Service)的更多相关文章

  1. asp.net core 阿里云消息服务(Message Service,原MQS)发送接口的实现

    最近在后台处理订单统计等相关功能用到了大力的mqs,由于官方没有实现asp.net core的sdk,这里简单实现了发送信息的功能,有兴趣的可以参考实现其他相关功能 using System;usin ...

  2. java消息服务学习之JMS概念

    JMS即Java消息服务(Java Message Service)应用程序接口是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送消息,进行异步通信. ...

  3. Java消息服务

    什么是消息? 消息是可编程实现两端通信的机制.通常的一些消息技术如:TCP/IP Sockets.管道.文件.共享存储. Java消息服务 Java消息服务,即Java Message Service ...

  4. Java消息服务初步学习(基于Spring In Action的整理)

    几个名词 Java消息服务(Java Message Service)是一个Java标准,定义了使用消息代理的通用API. 消息代理(message broker):类似于邮局的作用,确保消息被投递到 ...

  5. JMS(Java消息服务)与消息队列ActiveMQ基本使用(一)

    最近的项目中用到了mq,之前自己一直在码农一样的照葫芦画瓢.最近几天研究了下,把自己所有看下来的文档和了解总结一下. 一. 认识JMS 1.概述 对于JMS,百度百科,是这样介绍的:JMS即Java消 ...

  6. 【转载】JAVA消息服务JMS规范及原理详解

    转载:https://www.cnblogs.com/molao-doing/articles/6557305.html 作者: moyun- 一.简介 JMS即Java消息服务(Java Messa ...

  7. JAVA消息服务JMS规范及原理详解

    JAVA消息服务JMS规范及原理详解 一.简介 JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应 ...

  8. JMS(Java消息服务)

    JMS即Java消息服务(Java Message Service)应用程序接口是一个Java平台中关于面向消息中间件(MOM:指的是利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来 ...

  9. ActiveMQ学习总结(5)——Java消息服务JMS详解

    JMS: Java消息服务(Java Message Service) JMS是用于访问企业消息系统的开发商中立的API.企业消息系统可以协助应用软件通过网络进行消息交互. JMS的编程过程很简单,概 ...

随机推荐

  1. kubernetes配置secret拉取私仓镜像

    2017.05.10 19:48* 字数 390 阅读 5216评论 0喜欢 8 对于公司内部的项目, 我们不可能使用公有开放的镜像仓库, 一般情况可能会花钱买docker私仓服务, 或者说自己在服务 ...

  2. timer.Interval用法简介

    这个东东呢是我在做windows服务的时候碰到的,总结了一下她的用法,如下: 一.指定时间间隔 写一个每隔一分钟就执行一次的吧 public partial class PSJCService : S ...

  3. .net 里面打不出来ConfigurationManager

    ConfigurationManager 这个东东是读取配置文件时需要的. 首先要引用命名空间里面 using System.Configuration; 其次呢,在解决方案的引用里,单机右键进行添加

  4. Ubuntu 16.04开机自启Nginx简单脚本

    本文要记述的是最简单的Ubuntu下开机自启 nginx的脚本 这里将nginx装在了/usr/local/nginx目录下,nginx本身没有注册成服务,所以直接使用服务开机自启是不行的,除非自己写 ...

  5. sh脚本学习之:变量

    变量的创建 环境配置 /etc/profile =>~/.bash_profile(~/.bash_login,~/.profile) => ~/.bashrc sh声明 name=&qu ...

  6. CSS规范 - 分类方法--(来自网易)

    CSS文件的分类和引用顺序 通常,一个项目我们只引用一个CSS,但是对于较大的项目,我们需要把CSS文件进行分类. 我们按照CSS的性质和用途,将CSS文件分成“公共型样式”.“特殊型样式”.“皮肤型 ...

  7. 一个很实用的css3兼容工具很多属性可以兼容到IE6

    当你看到这样的效果图是不是已经崩溃了 css3没出来之前大部分人基本都是用图片的方式拼出来的 腾讯邮箱就是这么做的 然后你想和设计说换直角吧.我用图片的好烦的感觉!而且我们还要兼容到ie6 她和你说别 ...

  8. CF11D A Simple Task(状压DP)

    \(solution:\) 思路大家应该都懂: 状压DP:\(f[i][j]\),其中 \(i\) 这一维是需要状压的,用来记录19个节点每一个是否已经走过(走过为 \(1\) ,没走为 \(0\) ...

  9. 【ORACLE】创建表空间

    CREATE TABLESPACE dna36 DATAFILE 'D:\oracle\oradata\orcl\dna36.dbf' SIZE 100M AUTOEXTEND ON NEXT 10M ...

  10. Oracle PLSql配置

    1.安装Oracle客户端或者服务端 2.配置环境变量 <1>.一般如果安装了Oracle客户端或者服务端的话,在环境变种的Path中有Oracle的安装路径(计算机-属性-高级系统设置- ...