一、JMS是什么

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

2.JMS是一种与厂商无关的 API,用来访问收发系统消息,它类似于JDBC(Java Database Connectivity)。这里,JDBC 是可以用来访问许多不同关系数据库的 API,而 JMS 则提供同样与厂商无关的访问方法,以访问消息收发服务。

二、对象模型

1)连接工厂。连接工厂(ConnectionFactory)是由管理员创建,并绑定到JNDI树中。客户端使用JNDI查找连接工厂,然后利用连接工厂创建一个JMS连接。
2)JMS连接。JMS连接(Connection)表示JMS客户端和服务器端之间的一个活动的连接,是由客户端通过调用连接工厂的方法建立的。
3)JMS会话。JMS会话(Session)表示JMS客户与JMS服务器之间的会话状态。JMS会话建立在JMS连接上,表示客户与服务器之间的一个会话线程。
4)JMS目的。JMS目的(Destination),又称为消息队列,是实际的消息源。
5)JMS生产者和消费者。生产者(Message Producer)和消费者(Message Consumer)对象由Session对象创建,用于发送和接收消息。
6)JMS消息通常有两种类型:
  ① 点对点(Point-to-Point)。在点对点的消息系统中,消息分发给一个单独的使用者。点对点消息往往与队列(javax.jms.Queue)相关联。
  ② 发布/订阅(Publish/Subscribe)。发布/订阅消息系统支持一个事件驱动模型,消息生产者和消费者都参与消息的传递。生产者发布事件,而使用者订阅感兴趣的事件,并使用事件。该类型消息一般与特定的主题(javax.jms.Topic)关联。

三、两种通用类型特点

点对点消息模型有如下特性:

  1.每个消息只有一个接受者

    2.消息发送者和消息接受者并没有时间依赖性

       3.当消息发送者发送消息的时候,无论接收者程序在不在运行,都能获取到消息

发布/订阅消息模型有如下特性:

       1.一个消息可以传递给多个订阅者

       2.发布者和订阅者有时间依赖性,只有当客户端创建订阅后才能接受消息,且订阅者需一直保持活动状态以接收消息

  

四、上代码

  1.点对点模式:

    1).消息的生产者      

      package com.jinchi.jms;

      import javax.jms.Connection;
      import javax.jms.ConnectionFactory;
      import javax.jms.Destination;
      import javax.jms.JMSException;
      import javax.jms.MessageProducer;
      import javax.jms.Session;
      import javax.jms.TextMessage;

      import org.apache.activemq.ActiveMQConnection;
      import org.apache.activemq.ActiveMQConnectionFactory;

      public class JMSProducer {
      private static final String USERNAME=ActiveMQConnection.DEFAULT_USER; // 默认的连接用户名
      private static final String PASSWORD=ActiveMQConnection.DEFAULT_PASSWORD; // 默认的连接密码
      private static final String BROKEURL=ActiveMQConnection.DEFAULT_BROKER_URL; // 默认的连接地址
      private static final int SENDNUM=10; // 发送的消息数量
      /**
      * 消息生产者
      * @param args
      */
      public static void main(String[] args) {
      //连接工厂
      ConnectionFactory cFactory;
      //连接
      Connection connection = null;
      //会话
      Session session;
      //消息目的地
      Destination destination;
      //消息生产者
      MessageProducer messageProducer;
      //实例化工厂
      cFactory=new ActiveMQConnectionFactory(USERNAME,PASSWORD,BROKEURL);
      try {
      //通过工厂获得连接
      connection=cFactory.createConnection();
      //启动连接
      connection.start();
      //创建session
      session=connection.createSession(true, Session.AUTO_ACKNOWLEDGE);
      //创建消息队列
      destination=session.createQueue("FirstQueue1");
      //创建消息生产者
      messageProducer=session.createProducer(destination);
      //发送消息
      sendMessage(session,messageProducer);
      session.commit();
      } catch (Exception e) {
      e.printStackTrace();
      }finally {
      if (connection!=null) {
      try {
      connection.close();
      } catch (JMSException e) {
      e.printStackTrace();
      }
      }
      }
      }
      public static void sendMessage(Session session, MessageProducer messageProducer)throws Exception {
      for (int i = 0; i < SENDNUM; i++) {
      TextMessage textMessage=session.createTextMessage("ActiveMQ发送次数:"+i);
      System.out.println("发送消息:"+"ActiveMQ发送次数:"+i);
      messageProducer.send(textMessage);
      }
      }

      }

    2).消息的消费者  

      package com.jinchi.jms;

      import javax.jms.Connection;
      import javax.jms.ConnectionFactory;
      import javax.jms.Destination;
      import javax.jms.JMSException;
      import javax.jms.MessageConsumer;
      import javax.jms.Session;

      import org.apache.activemq.ActiveMQConnection;
      import org.apache.activemq.ActiveMQConnectionFactory;

      public class JMSconsumer2 {
      private static final String USERNAME=ActiveMQConnection.DEFAULT_USER;
      private static final String PASSWORD=ActiveMQConnection.DEFAULT_PASSWORD;
      private static final String BORK_STRING=ActiveMQConnection.DEFAULT_BROKER_URL;
      public static void main(String[] args) {
      //连接工厂
      ConnectionFactory cFactory;
      //连接
      Connection connection;
      //会话
      Session session;
      //消费的目的地
      Destination destination;
      //消息的消费者
      MessageConsumer messageConsumer;
      //实例化工厂
      cFactory=new ActiveMQConnectionFactory(USERNAME,PASSWORD,BORK_STRING);
      try {
      //通过工厂获取连接对象
      connection=cFactory.createConnection();
      //启动连接
      connection.start();
      //创建会话
      session=connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
      //创建连接的消息队列
      destination=session.createQueue("FirstQueue1");
      //创建消息消费者
      messageConsumer=session.createConsumer(destination);
      //注册消息监听
      messageConsumer.setMessageListener(new JMSListenre());
      } catch (JMSException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
      }
      }

      }

    3).消息消费者监听事件   

      package com.jinchi.jms;

      import javax.jms.JMSException;
      import javax.jms.Message;
      import javax.jms.MessageListener;
      import javax.jms.TextMessage;

      /**
      * 消息监听
      * @author Admin
      *
      */
      public class JMSListenre implements MessageListener{

      @Override
      public void onMessage(Message message) {
      try {
      System.out.println("收到的消息:"+((TextMessage)message).getText());
      } catch (JMSException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
      }
      }

      }

  2.发布/订阅消息模型:

    1).消息的发布者

      package com.jinchi.jms2;

      import javax.jms.Connection;
      import javax.jms.ConnectionFactory;
      import javax.jms.Destination;
      import javax.jms.JMSException;
      import javax.jms.MessageProducer;
      import javax.jms.Session;
      import javax.jms.TextMessage;

      import org.apache.activemq.ActiveMQConnection;
      import org.apache.activemq.ActiveMQConnectionFactory;

      public class JMSProducer {
      private static final String USERNAME=ActiveMQConnection.DEFAULT_USER;
      private static final String PASSWORD=ActiveMQConnection.DEFAULT_PASSWORD;
      private static final String BORK=ActiveMQConnection.DEFAULT_BROKER_URL;
      private static final int SEND=10;
      public static void main(String[] args) {
      // 连接工厂
      ConnectionFactory cFactory;
      //连接
      Connection connection = null;
      //会话
      Session session;
      //消息的目的地
      Destination destination;
      //消息的生产者
      MessageProducer messageProducer;
      //实例化工厂
      cFactory=new ActiveMQConnectionFactory(USERNAME,PASSWORD,BORK);
      try {
      //通过工厂获取连接对象
      connection=cFactory.createConnection();
      //连接
      connection.start();
      //会话
      session=connection.createSession(true, Session.AUTO_ACKNOWLEDGE);
      //创建消息队列
      destination=session.createTopic("FirstQueue2");
      //创建消息生产者
      messageProducer=session.createProducer(destination);
      //发送消息
      sendMessage(session,messageProducer);
      session.commit();
      } catch (JMSException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
      }finally {
      if (connection!=null) {
      try {
      connection.close();
      } catch (JMSException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
      }
      }
      }

      }
      public static void sendMessage(Session session, MessageProducer messageProducer) {
      for (int i = 0; i < SEND; i++) {
      try {
      TextMessage textMessage=session.createTextMessage("ActiveMQ发送次数:"+i);
      System.out.println("发送消息:"+"ActiveMQ发送次数:"+i);
      //发送
      messageProducer.send(textMessage);
      } catch (JMSException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
      }
      }
      }

      }

    2).消息的订阅者,需要创建两个订阅者,用于查看发布的消息是否都能被两个订阅者消费

      ①第一个订阅者:    

      package com.jinchi.jms2;

      import javax.jms.Connection;
      import javax.jms.ConnectionFactory;
      import javax.jms.Destination;
      import javax.jms.JMSException;
      import javax.jms.MessageConsumer;
      import javax.jms.Session;

      import org.apache.activemq.ActiveMQConnection;
      import org.apache.activemq.ActiveMQConnectionFactory;

      public class JMSconsumer {
      private static final String USERNAME=ActiveMQConnection.DEFAULT_USER;
      private static final String PASSWORD=ActiveMQConnection.DEFAULT_PASSWORD;
      private static final String BORKURL=ActiveMQConnection.DEFAULT_BROKER_URL;

      public static void main(String[] args) {
      //连接工厂
      ConnectionFactory cFactory;
      //连接
      Connection connection;
      //会话
      Session session;
      //消费目的地
      Destination destination;
      //消息消费者
      MessageConsumer messageConsumer;
      //实例化工厂
      cFactory =new ActiveMQConnectionFactory(USERNAME,PASSWORD,BORKURL);
      try {
      //通过工厂获取连接对象
      connection=cFactory.createConnection();
      //启动
      connection.start();
      //会话
      session=connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
      //消费目的地
      destination=session.createTopic("FirstQueue2");
      //创建消息消费者
      messageConsumer=session.createConsumer(destination);
      //创建消费者监听
      messageConsumer.setMessageListener(new JMSListener1());
      } catch (JMSException e) {
      e.printStackTrace();
      }

      }

      }

      第一个订阅者监听事件:  

      package com.jinchi.jms2;

      import javax.jms.JMSException;
      import javax.jms.Message;
      import javax.jms.MessageListener;
      import javax.jms.TextMessage;

      public class JMSListener1 implements MessageListener{

      @Override
      public void onMessage(Message message) {
      try {
      System.out.println("订阅者一收到的消息:"+((TextMessage)message).getText());
      } catch (JMSException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
      }

      }

      }

      ②第二个订阅者:    

      package com.jinchi.jms2;

      import javax.jms.Connection;
      import javax.jms.ConnectionFactory;
      import javax.jms.Destination;
      import javax.jms.JMSException;
      import javax.jms.MessageConsumer;
      import javax.jms.Session;

      import org.apache.activemq.ActiveMQConnection;
      import org.apache.activemq.ActiveMQConnectionFactory;

      public class JMSconsumer2 {
      private static final String USERNAME=ActiveMQConnection.DEFAULT_USER;
      private static final String PASSWORD=ActiveMQConnection.DEFAULT_PASSWORD;
      private static final String BORKURL=ActiveMQConnection.DEFAULT_BROKER_URL;

      public static void main(String[] args) {
      //连接工厂
      ConnectionFactory cFactory;
      //连接
      Connection connection;
      //会话
      Session session;
      //消息目的地
      Destination destination;
      //消息消费者
      MessageConsumer messageConsumer;
      //实例化工厂
      cFactory=new ActiveMQConnectionFactory(USERNAME,PASSWORD,BORKURL);
      try {
      //通过工厂获取连接对象
      connection=cFactory.createConnection();
      //连接
      connection.start();
      //会话
      session=connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
      //消费的目的地
      destination=session.createTopic("FirstQueue2");
      //创建消息消费者
      messageConsumer=session.createConsumer(destination);
      //创建消息监听
      messageConsumer.setMessageListener(new JMSListener2());
      } catch (JMSException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
      }

      }

      }

      第二个订阅者监听事件:   

      package com.jinchi.jms2;

      import javax.jms.JMSException;
      import javax.jms.Message;
      import javax.jms.MessageListener;
      import javax.jms.TextMessage;

      public class JMSListener2 implements MessageListener{

      @Override
      public void onMessage(Message message) {
      try {
      System.out.println("订阅者二收到的消息:"+((TextMessage)message).getText());
      } catch (JMSException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
      }
      }
      }

  测试发布/订阅消息模型时,先启动两个订阅者,然后再启动发布者,否则无法达到真正的测试。

      

JMS入门简介的更多相关文章

  1. 消息中间件 JMS入门

    1. JMS入门 1.1消息中间件 什么是消息中间件 消息中间件利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成.通过提供消息传递和消息排队模型,它可以在分布式环 ...

  2. 掌握 Ajax,第 1 部分: Ajax 入门简介

    转:http://www.ibm.com/developerworks/cn/xml/wa-ajaxintro1.html 掌握 Ajax,第 1 部分: Ajax 入门简介 理解 Ajax 及其工作 ...

  3. MongoDB入门简介

    MongoDB入门简介 http://blog.csdn.net/lolinzhang/article/details/4353699 有关于MongoDB的资料现在较少,且大多为英文网站,以上内容大 ...

  4. (转)Web Service入门简介(一个简单的WebService示例)

    Web Service入门简介 一.Web Service简介 1.1.Web Service基本概念 Web Service也叫XML Web Service WebService是一种可以接收从I ...

  5. NodeJS入门简介

    NodeJS入门简介 二.模块 在Node.js中,以模块为单位划分所有功能,并且提供了一个完整的模块加载机制,这时的我们可以将应用程序划分为各个不同的部分. const http = require ...

  6. ASP.NET Core学习之一 入门简介

    一.入门简介 在学习之前,要先了解ASP.NET Core是什么?为什么?很多人学习新技术功利心很重,恨不得立马就学会了. 其实,那样做很不好,马马虎虎,联系过程中又花费非常多的时间去解决所遇到的“问 ...

  7. webservice入门简介

    为了梦想,努力奋斗! 追求卓越,成功就会在不经意间追上你 webservice入门简介 1.什么是webservice? webservice是一种跨编程语言和跨操作系统平台的远程调用技术. 所谓的远 ...

  8. Web Service入门简介(一个简单的WebService示例)

    Web Service入门简介 一.Web Service简介 1.1.Web Service基本概念 Web Service也叫XML Web Service WebService是一种可以接收从I ...

  9. Android精通教程-第一节Android入门简介

    前言 大家好,给大家带来Android精通教程-第一节Android入门简介的概述,希望你们喜欢 每日一句 If life were predictable it would cease to be ...

随机推荐

  1. 并发编程-concurrent指南-阻塞队列-延迟队列DelayQueue

    DelayQueue是一个无界的BlockingQueue,用于放置实现了Delayed接口的对象,其中的对象只能在其到期时才能从队列中取走.这种队列是有序的,即队头对象的延迟到期时间最长.注意:不能 ...

  2. scrapy实战5 POST方法抓取ajax动态页面(以慕课网APP为例子):

    在手机端打开慕课网,fiddler查看如图注意圈起来的位置 经过分析只有画线的page在变化 上代码: items.py import scrapy class ImoocItem(scrapy.It ...

  3. bs4——BeautifulSoup模块:解析网页

    解析由requests模块请求到的网页 import requests from bs4 import BeautifulSoup headers = {'User-Agent': 'Mozilla/ ...

  4. mysql数据库建表分类字段--尽量少用字符串--原因探索

    虽然一直都知道,类型 之类的字段 直接用字符窜会很方便,不过最好还是不要用字符串:但是也不是特别清楚为什么不要用,时间久了 就忍不住用一下字符窜试试,这一试 还挺好用的,吓得我 感觉探究了一下 为什么 ...

  5. weblogic10.3.6重置/修改控制台账号密码

    weblogic部署服务后由于交接过程中文档不完整导致有一个域的控制台账号密码遗失, 在此整理记录一下重置控制台账号密码的过程: 注:%DOMAIN_HOME%:指WebLogic Server 域( ...

  6. 后端 - Lession 01 PHP 基础

    目录 Lession 01 php 基础 1. php 基础 2. php 变量 3. php 单引号 和 双引号区别 4. 数据类型 5. 数据类型转换 6. 常量 7. 运算符 8. 为 fals ...

  7. SQL Server 设置默认数据库

    STEP 1 调用系统函数 查看SQL Server的当前用户名 SELECT SUSER_NAME(); NOTE : 系统函数的调用跟sql语句执行一样 Paste_Image.png 运行结果 ...

  8. Java:jdbc连接mysql数据库

    安装eclipse和mysql的步骤这里不赘述了. 1.一定要下jar包 要想实现连接数据库,要先下载mysql-connector-java-5.1.47(或者其他版本)的jar包.低版本的jar包 ...

  9. nl2br()处理字符串中的换行符

    nl2br() 函数 在字符串中包含换行符时,需要对其进行转换,php 中有str_replace()函数,可以直接对字符串进行替换处理.但php中还有nl2br()函数可以直接处理. 1.在字符串中 ...

  10. Spring Boot如何设计防篡改、防重放攻击接口

    Spring Boot 防篡改.防重放攻击 本示例要内容 请求参数防止篡改攻击 基于timestamp方案,防止重放攻击 使用swagger接口文档自动生成 API接口设计 API接口由于需要供第三方 ...