了解JMS

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

JMS涉及到的接口:

ConnectionFactory : 客户用来创建连接(connection)的对象.
Connection: 封装了客户和JMS之间的一个虚拟连接.
Session: 是生产和消费的一个单线程上下文,用来创建消息生产者(Producer)消息消费者(Consumer);会话提供一个事务上下文,在这个上下文中一组
消息接收和发送放在一个原子操作中.
Destination:目的地是客户用来指定它生产的消息的目标和它消费的消息的来源的对象。JMS1.0.2规范中定义了两种消息传递域:点对点(PTP)消息传递域和发布/订阅消息传递域。 点对点消息传递域的特点如下:
  • 每个消息只能有一个消费者。
  • 消息的生产者和消费者之间没有时间上的相关性。无论消费者在生产者发送消息的时候是否处于运行状态,它都可以提取消息。发布/订阅消息传递域的特点如下:
  • 每个消息可以有多个消费者。
  • 生产者和消费者之间有时间上的相关性。订阅一个主题的消费者只能消费自它订阅之后发布的消息。JMS规范允许客户创建持久订阅,这在一定程度上放松了时间上的相关性要求。持久订阅允许消费者消费它在未处于激活状态时发送的消息。在点对点消息传递域中,目的地被成为队列(queue);在发布/订阅消息传递域中,目的地被成为主题(topic)。

MessageProducer:消息生产者是由会话创建的一个对象,用于把消息发送到一个目的地。
MessageConsumer:消息消费者是由会话创建的一个对象,它用于接收发送到目的地的消息。消息的消费可以采用以下两种方法之一:
  • 同步消费。通过调用消费者的receive方法从目的地中显式提取消息。receive方法可以一直阻塞到消息到达。
  • 异步消费。客户可以为消费者注册一个消息监听器,以定义在消息到达时所采取的动作。

JMS消息由以下三部分组成的:
  • 消息头。每个消息头字段都有相应的getter和setter方法。
  • 消息属性。如果需要除消息头字段以外的值,那么可以使用消息属性。
  • 消息体。JMS定义的消息类型有TextMessage、MapMessage、BytesMessage、StreamMessage和ObjectMessage。

ActiveMQ

ActiveMQ是apache的一个开源的消息中间件:

下载地址: http://activemq.apache.org/activemq-5144-release.html

目前最新版为: 5.14.4

下载后解压,目录如下:

bin 目录是运行命令

conf 是配置

data 存放日志以及持久化文件

lib  中是一些依赖包

进入bin目录,根据计算机选择win32/win64进入目录,双击activemq.bat即可运行ActiveMQ,其运行在一个jetty的web容器上,默认端口为8161默认管理员账号和密码分别为admin,这些都是在配置文件中进行配置的,后续将详细说明.

登录后,即进入如下页面:

如下代码实现一个holleword的入门程序:

消息生产方代码(示例代码异常直接抛出了):

  1. public class Sender {
  2. public static void main(String[] args) throws Exception {
  3. /**
  4. 1. 创建connectionFactory
  5. * 第一个参数: 用户名
  6. * 第二个参数: 密码
  7. * 第三个参数: 访问的地址
  8. */
  9. ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(//
  10. ActiveMQConnectionFactory.DEFAULT_USER,//
  11. ActiveMQConnectionFactory.DEFAULT_PASSWORD,//
  12. "tcp://localhost:61616");
  13. /**
  14. 2. 获取Connection
  15. a. 可以不在上面的创建connection工厂的时候设置用户名和密码
  16. * b. 当使用connectionFactory获取多个connection的时候,再设置用户名和密码;
  17. * connectionFactory.createConnection(ActiveMQConnectionFactory.DEFAULT_USER,
  18. * ActiveMQConnectionFactory.DEFAULT_PASSWORD);
  19. */
  20. Connection connection = connectionFactory.createConnection();
  21. connection.start();
  22.  
  23. /**
  24. 3. 获取Session,参数说明如下:
  25. * 第一个参数: 表示是否开启事务,TRUE表示开启,FALSE表示不开启,
  26. * 如果开启事务则在发送消息后需要使session.commit();进行事务提交。
  27. * 第二个参数: 表示接收消息后通知MQ的方式
  28. */
  29. Session session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE);
  30.  
  31. /**
  32. 4. 获取Destination参数表示目标消息位置的名称
  33. */
  34. Destination detination = session.createQueue("myqueue");
  35.  
  36. /**
  37. 5. 获取producer
  38. * 参数表示生产者将消息发送到的位置;如果producer要向多个目的位置发送消息的,在此可以设置为null,然后在发送
  39. * 消息的时候再设置消息目的地
  40. */
  41. MessageProducer producer = session.createProducer(detination);
  42.  
  43. //设置不持久化
  44. producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
  45.  
  46. /**
  47. 6. 创建TextMessage
  48. */
  49. TextMessage text = new ActiveMQTextMessage();
  50. text.setText("这是消息内容.");
  51.  
  52. /**
  53. 7. 发送消息
  54. * 可以在发送消息的时候设置:目的地,消息体,是否持久化,消息级别,等待时长分别对应如下的参数
  55. * producer.send(Destination detination,Message message, int deliveryMode, int priority, long timeToLive);
  56. */
  57. producer.send(text);
  58.  
  59. /**
  60. 8. 关闭connection
  61. * 发送完消息记得关闭connection,不然每次创建connetion会消耗尽服务内存;
  62. * 只需要关闭connection即可,其他session等在connection关闭的时候同时自动关闭.
  63. */
  64. if(connection != null){
  65. connection.close();
  66. }
  67. }
  68. }

消息消费方代码:

  1. public class Receiver {
  2.  
  3. public static void main(String[] args) throws Exception {
  4. //1. 创建connectionFactory
  5. ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(//
  6. ActiveMQConnectionFactory.DEFAULT_USER,//
  7. ActiveMQConnectionFactory.DEFAULT_PASSWORD,//
  8. "tcp://localhost:61616");
  9. /**
  10. 2. 获取Connection
  11. a. 可以不在上面的创建connection工厂的时候设置用户名和密码
  12. * b. 当使用connectionFactory获取多个connection的时候,再设置用户名和密码;
  13. * connectionFactory.createConnection(ActiveMQConnectionFactory.DEFAULT_USER,
  14. * ActiveMQConnectionFactory.DEFAULT_PASSWORD);
  15. */
  16. Connection connection = connectionFactory.createConnection();
  17. connection.start();
  18.  
  19. /**
  20. 3. 获取Session,参数说明如下:
  21. * 第一个参数: 表示是否开启事务,TRUE表示开启,FALSE表示不开启,
  22. * 如果开启事务则在发送消息后需要使session.commit();进行事务提交。
  23. * 第二个参数: 表示接收消息后通知MQ的方式
  24. */
  25. Session session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE);
  26.  
  27. /**
  28. 4 获取Destination
  29. * 参数表示目标消息的位置,使用session获取多个Destinnation的时候可以传 null,在进行消息发送或者接收的时候
  30. * 再设置目的Destination的名称.
  31. */
  32. Destination detination = session.createQueue("myqueue");
  33.  
  34. /**
  35. 5. 获取producer
  36. * 参数表示生产者将消息发送到的位置;如果producer要向多个目的位置发送消息的,在此可以设置为null,然后在发送
  37. * 消息的时候再设置消息目的地
  38. */
  39. MessageConsumer consumer = session.createConsumer(detination);
  40.  
  41. while(true){
  42. /**
  43. * 获取消息;
  44. * consumer.receive(); 阻塞式接收
  45. * consumer.receiveNoWait(); 不阻塞不等待
  46. * consumer.receive(long time); 等待多久
  47. */
  48. TextMessage text = (TextMessage) consumer.receive();
  49. System.out.println("消费端:" + text.getText());
  50. }
  51. }
  52. }

以上简单的通过ActiveMQ进行消息生产和消费的实现, 生产者和消费者之间进行了解耦,没有生命周期以及程序调用的关联性;开启ActiveMQ分别运行Sender和Receiver端,就可以在Receiver端接收到Sender端发送的消息.

ActiveMQ (一) 初识ActiveMQ的更多相关文章

  1. ActiveMQ(1)---初识ActiveMQ

    消息中间件的初步认识 什么是消息中间件? 消息中间件是值利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成.通过提供消息传递和消息排队模型,可以在分布式架构下扩展进 ...

  2. [ActiveMQ]初识ActiveMQ

    初识ActiveMQ ActiveMQ介绍 官方网站:http://activemq.apache.org/ 最新版本:ActiveMQ 5.14.1(2016-10-28) 最新版本下载链接:htt ...

  3. ActiveMQ学习笔记(1)----初识ActiveMQ

    1. 什么是ActiveMQ? ActiveMQ是Apache推出的,一款开源的,完全支持JMS1.1和j2ee1.4规范的JMS Provider实现的消息中间件(Message Oriented ...

  4. Web项目容器集成ActiveMQ & SpringBoot整合ActiveMQ

    集成tomcat就是随项目启动而启动tomcat,最简单的方法就是监听器监听容器创建之后以Broker的方式启动ActiveMQ. 1.web项目中Broker启动的方式进行集成 在这里采用Liste ...

  5. ActiveMQ介绍和ActiveMQ入门实例

    ActiveMQ百度百科   ActiveMQ入门实例-cnblogs.com      作者用的是5.5的版本,我测试时用的是5.6,按照作者说的整了一下,走得通

  6. 初识 ActiveMQ

    其实算不上初识了,工作一年来一直都有接触 mq 相关的东西.但是,从来都是粘贴复制别人的配置代码,却从未认真系统的学习过它,现在线上用 mq 的项目出问题了,老板在后面拿枪指着呢,不得不好好研究下了. ...

  7. 初识ActiveMQ

    消息中间件的初步认识 什么是消息中间件? 消息中间件是利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成.通过提供消息传递和消息排队模型,可以在分布式架构下扩展进程 ...

  8. SpringBoot第二十篇:初识ActiveMQ

    本文是作者之前写的关于 ActiveMQ 的一篇文章.此处为了保证该系列文章的完整性,故此处重新引入. 一.消息中间件的介绍 介绍 消息队列 是指利用 高效可靠 的 消息传递机制 进行与平台无关的 数 ...

  9. 学习ActiveMQ(八):activemq消息的持久化

    1. 持久化方式介绍前面我们也简单提到了activemq提供的插件式的消息存储,在这里再提一下,主要有以下几种方式: AMQ消息存储-基于文件的存储方式,是activemq开始的版本默认的消息存储方式 ...

随机推荐

  1. Akka(40): Http:Marshalling reviewed - 传输数据序列化重温

    上篇我们讨论了Akka-http的文件交换.由于文件内容编码和传输线上数据表达型式皆为bytes,所以可以直接把文件内容存进HttpEntity中进行传递.那么对于在内存里自定义的高级数据类型则应该需 ...

  2. Imageloader框架

    package adapter;import android.content.Context;import android.graphics.Bitmap;import android.graphic ...

  3. HDU4508--完全背包

    湫湫系列故事--减肥记I Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others) Tot ...

  4. bitcms 一个迟到的项目,一个老程序的项目总结

    经历长达两年的开发,两个版本的更换.bitcms要终于面世了.先来接受大家的吐嘈.项目文档,慢慢完善中... 首先先来介绍下项目 bitcms是由asp.net开发,sqlite为数据库的开源内容管理 ...

  5. kubernetes nginx ingress 使用记录

    前言 ingress是一种可以暴露k8s集群内部service的方式,用户编辑配置文件定义一个ingress资源即可实现外部网络访问内网service. ingress controller是来管理所 ...

  6. 使用hiredis实现pipeline方式访问

    1.介绍 hiredis: 一个c/c++的访问redis的api库 地址:https://github.com/redis/hiredis pipeline方式: redis中的pipeline方式 ...

  7. JDBC的使用

    JDBC详解系列(一)之流程 ---[来自我的CSDN博客](http://blog.csdn.net/weixin_37139197/article/details/78838091)---   使 ...

  8. 运行循环 - RunLoop

    1.RunLoop简介 1.1 什么是RunLoop 简单来说就是:运行循环,可以理解成一个死循环,一直在运行. RunLoop实际上就是一个对象,这个对象用来处理程序运行过程中出现的各种事件(触摸. ...

  9. BEGINNING SHAREPOINT® 2013 DEVELOPMENT 第8章节--配送SP2013Apps

    BEGINNING SHAREPOINT® 2013 DEVELOPMENT 第8章节--配送SP2013Apps         本章节你将学到: 通过SP商店配送Apps: 在商店授予证书并管理A ...

  10. Codeforces Round #261 (Div. 2)459D. Pashmak and Parmida's problem(求逆序数对)

    题目链接:http://codeforces.com/contest/459/problem/D D. Pashmak and Parmida's problem time limit per tes ...