JMS:

JMS基本概念:

JMS(Java Message Service) 即Java消息服务。它提供标准的产生、发送、接收消息的接口简化企业应用的开发。它支持两种消息通信模型:点到点(point-to-point)(P2P)模型和发布/订阅(Pub/Sub)模型。

1)点对点方式(point-to-point)

点对点的消息发送方式主要建立在 Message Queue,Sender,Receiver上,Message Queue 存贮消息,Sender发送消息,Receiver接收消息.具体点就是Sender Client发送Message 到Queue中 ,而Receiver Client从Queue中接收消息和\发送消息已接受\到Quere,确认消息接收。消息发送客户端与接收客户端没有时间上的依赖,发送客户端可以在任何时刻发送信息到Queue,而不需要知道接收客户端是不是在运行

2)发布/订阅 方式(publish / subscribe)

发布/订阅方式用于多接收客户端的方式.作为发布订阅的方式,可能存在多个接收客户端,并且接收端客户端与发送客户端存在时间上的依赖。一个接收端只能接收他创建以后发送客户端发送的信息。作为subscriber ,在接收消息时有两种方法,destination的receive方法,和实现message listener 接口的onMessage 方法。

几个重要概念:

Destination:消息发送的目的地,也就是所谓的Queue和Topic。创建好一个消息之后,只需要把这个消息发送到目的地,消息的发送者就可以继续做自己的事情,而不用等待消息被处理完成。至于这个消息什么时候,会被哪个消费者消费,完全取决于消息的接受者。 Message:从字面上就可以看出是被发送的消息。它有下面几种类型:

StreamMessage:Java 数据流消息,用标准流操作来顺序的填充和读取。

MapMessage:一个Map类型的消息;名称为 string 类型,而值为 Java 的基本类型。 TextMessage:普通字符串消息,包含一个String。

ObjectMessage:对象消息,包含一个可序列化的Java 对象 BytesMessage:二进制数组消息,包含一个byte[]。 XMLMessage: 一个XML类型的消息。

最常用的是TextMessage和ObjectMessage。

Session:与JMS提供者所建立的会话,通过Session我们才可以创建一个Message。

Connection:与JMS提供者建立的一个连接。可以从这个连接创建一个会话,即Session。 ConnectionFactory:那如何创建一个Connection呢?这就需要下面讲到的

ConnectionFactory了。通过这个工厂类就可以得到一个与JMS提供者的连接,即Conection。

Producer:消息的生产者,要发送一个消息,必须通过这个生产者来发送。

MessageConsumer:与生产者相对应,这是消息的消费者或接收者,通过它来接收一个消息。

ActiveMQ:

ActiveMQ 是Apache出品,能力强劲的开源的消息总线。ActiveMQ 是一个完全支持JMS和J2EE规范的 JMS Provider实现。

在官方地址: http://activemq.apache.org/上可以下载到ActiveMQ,我们使用的是ActiveMQ5.2版本,下载apache-activemq-5.2.0-bin.zip到本地,解压缩之后即可使用。在相对应解压目录下的apache-activemq-5.2.0\\bin\\中找到activemq.bat运行它,ActiveMQ就运行起来了。需要注意的是,在运行ActiveMQ之前需要在环境变量中配置好

JAVA_HOME ,PATH和CLASSPATH。

ActiveMQ的默认的监听端口为61616,可以在activemq.xml文件中进行修改,建议不要进行修改。另外在ActiveMQ启动之后,可以在ActiveMQ的控制台http://localhost:8161/admin/中查看运行的状态,进行各种操作。

一个典型的JMS程序的创建过程:

1.通过jndi查询ConnectionFactory(这个jndi的配置是针对具体的jms提供者的,如ActiveMQ 就使用org.apache.activemq.ActiveMQConnectionFactory) 2.使用ConnectionFactory创建一个Connnection。 3.启动Connection。

4.使用Connection创建一个或者多个Session 5.通过jndi查询一个或者多个Destination。

6.使用session和Destination创建对应的MessageProducer和MessageConsumer。 按照上面过程得到这样一个简图,

ConnectionFactory---->Connection--->Session--->Message

Destination + Session------------------------------------>Producer

Destination + Session------------------------------------>MessageConsumer

我们使用ActiveMQ去实现这个简单的JMS程序: ? 首先需要得到ConnectionFactoy。 ConnectionFactory factory = new ActiveMQConnectionFactory(url); ? 然后又ConnectionFactory创建一个Connection, 再启动这个Connection: Connection connection = factory.createConnection(); connection.start(); ? 接下来需要由Connection创建一个Session: Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE) ? 获得Destination,这里创建一个Queue作为Destination。 Destination destination = session.createQueue(\? 下面就可以创建Message了,这里创建一个TextMessage。 Message message = session.createTextMessage(\? 要想把刚才创建的消息发送出去,需要由Session和Destination创建一个消息生产者: MessageProducer producer = session.createProducer(queue); ? 下面就可以发送刚才创建的消息了: producer.send(message); ? 消息发送完成之后,我们需要创建一个消息消费者来接收这个消息: MessageConsumer comsumer = session.createConsumer(queue); Message recvMessage = comsumer.receive(); ? 消息消费者接收到这个消息之后,就可以得到它的内容: System.out.println(((TextMessage)recvMessage).getText());

从而得到这个简单的JMS的程序如下,在运行这个程序之前,你需要在所建工程中导入2个jar包javax.jms.jar(可以在网上下载到)和activemq-all-5.2.0.jar(在/apache-activemq-5.2.0/下) import javax.jms.*; import org.apache.activemq.ActiveMQConnectionFactory;

public class MessageSendAndReceive {

public static void main(String[] args) throws Exception {

ConnectionFactory factory = new ActiveMQConnectionFactory( \

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

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

Destination destination = session.createQueue(\ Message message = session.createTextMessage(\ MessageProducer producer = session .createProducer(destination); producer.send(message);

System.out.println(\ MessageConsumer comsumer = session .createConsumer(destination);

Message recvMessage = comsumer.receive(); System.out.println(\

+ ((TextMessage) recvMessage).getText()); } }

启动ActiveMQ后,运行上面的程序将会得到如下结果:

Send Message Completed! Received:Hello JMS!

小实验:在前面介绍到,接收消息时有两种方法,destination的receive方法,和实现message listener 接口的onMessage 方法。现在我们要编写一个消息监听者,监听队列,当队列里一旦有消息则自动接收队列里的消息。 import javax.jms.*; import org.apache.activemq.ActiveMQConnection; import org.apache.activemq.ActiveMQConnectionFactory; public class Jms_Receiver_Listener extends Thread implements MessageListener, ExceptionListener { // ConnectionFactory :连接工厂,JMS 用它创建连接 ConnectionFactory connectionFactory; // Connection :JMS 客户端到JMS Provider 的连接 Connection connection = null; // Session: 一个发送或接收消息的线程 Session session;

// Destination :消息的目的地 Destination destination; //消息接收者

MessageConsumer consumer;

public Jms_Receiver_Listener() {

String url = \

// 在ActiveMq的console配置的queue的名字 String queue =\

connectionFactory = new ActiveMQConnectionFactory( ActiveMQConnection.DEFAULT_USER,

ActiveMQConnection.DEFAULT_PASSWORD, url); // 构造从工厂得到连接对象 try {

connection = connectionFactory.createConnection(); connection.setExceptionListener(this);// 异常处理 connection.start();// 连接启动

//如果为true,则队列里面的消息没有被取走,继续存在 session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); // 获取session,

destination = session.createQueue(queue);

consumer = session.createConsumer(destination); } catch (JMSException e) {

System.err.println(\ e.printStackTrace(); } }

public void run() { try {

consumer.setMessageListener(this); } catch (JMSException e) { System.err

.println(\ e.printStackTrace(); } }

public void onMessage(Message message) { try {

if (message instanceof TextMessage) {

TextMessage txtMsg = (TextMessage) message; String msg = txtMsg.getText();

}

System.out.println(\ }

} catch (JMSException e) { System.err

.println(\ e.printStackTrace(); } }

// 异步消息异常处理

public void onException(JMSException arg0) { System.err.println(\异常!\}

//测试程序

public static void main(String[] args) {

Jms_Receiver_Listener jrl = new Jms_Receiver_Listener(); jrl.start(); }

运行上面的程序,一旦队列TestQueue队列中有消息,监听就会从队列中取出消息,打印到控制台上。

Received: 学习ActiveMQ 发送消息 1 Received: 学习ActiveMQ 发送消息2 Selector:

前面用到的消息接收者的创建方式是:session.createConsumer(destination),这种方式,消息的接收者会把所有消息接收到,而如果只要选择性的接受你想要的消息,就需要使用consumer = session.createConsumer(destination,selector)的方式。

假设,有多个消息的监听者同时监听同一个队列,使用这种方式就可以根据selector来对队列中的消息进行过滤,只有符合selector的消息才会从队列中被取出来,不符合的消息还保留在队列中。

首先在消息的发送方,发送消息之前对消息设置属性:

message.setStringProperty(\这样在消息接收方使用selector的方式为:

consumer = session.createConsumer(destination,\’ \其他地方不需要做任何变化,这样消息的监听者只会接收MessageID为1001的消息,而其他消息不会取出,仍然放在队列中。

activeMQ的回顾的更多相关文章

  1. activemq的几种基本通信方式总结

    简介 在前面一篇文章里讨论过几种应用系统集成的方式,发现实际上面向消息队列的集成方案算是一个总体比较合理的选择.这里,我们先针对具体的一个消息队列Activemq的基本通信方式进行探讨.activem ...

  2. 分布式ActiveMQ集群--转载

    原文地址:http://shensy.iteye.com/blog/1752529 回顾总结前一段时间学习的ActiveMQ分布式集群相关的知识,分享出来希望对看到的人有所帮助. 一.分布式Activ ...

  3. activemq的两种基本通信方式的使用及总结

    简介 在前面一篇文章里讨论过几种应用系统集成的方式,发现实际上面向消息队列的集成方案算是一个总体比较合理的选择.这里,我们先针对具体的一个消息队列Activemq的基本通信方式进行探讨.activem ...

  4. Java消息队列-Spring整合ActiveMq

    1.概述 首先和大家一起回顾一下Java 消息服务,在我之前的博客<Java消息队列-JMS概述>中,我为大家分析了: 消息服务:一个中间件,用于解决两个活多个程序之间的耦合,底层由Jav ...

  5. ActiveMq笔记1-消息可靠性理论

    原博客:http://shift-alt-ctrl.iteye.com/blog/2020182 https://mp.weixin.qq.com/s/h74d6LtGB5M8VF0oLrXdCA 我 ...

  6. 大数据入门第三天——基础补充与ActiveMQ

    一.多线程基础回顾 先导知识在基础随笔篇:http://www.cnblogs.com/jiangbei/p/6664555.html 以下此部分以补充为主 1.概念 进程:进行中的程序,内存中有独立 ...

  7. ActiveMQ与SpringMVC整合实现发送PTP和订阅发布消息功能

    实现一个基于SpringMVC+JMS+ActiveMQ+Tomcat+JDK1.8+IDEA工具 ,Spring4.1.0和ActiveMQ5.15整合的实例,实现PTP和订阅/发布两种消息模型 一 ...

  8. activemq 实战 一

    This chapter covers  Introduction to the use case for each of the book examples  Use of Maven for ...

  9. 理解面向消息中间件及JMS 以及 ActiveMQ例子

    为了帮助你理解ActiveMQ的意义,了解企业消息传送背景和历史是很重要的.讨论完企业消息传送,你将可以通过一个小例子了解JMS及其使用.这章的目的是简要回顾企业消息传送及JMS规范.如果你已经熟悉这 ...

随机推荐

  1. LinkedList底层代码解析笔记

    LinkedList是属于Sequence List,故遍历是用迭代器更快; LinkedList继承自AbstractSequenceList.实现了List及Deque接口.其实AbstractS ...

  2. Android中XML的命名空间、自定义属性

    命名空间(namespace) XML 命名空间提供避免元素命名冲突的方法. 举个例子,A学校有名学生叫做林小明,B学校也有名学生叫林小明,那我们如何识别这两名拥有相同名字的同学呢?这时候命名空间就派 ...

  3. C#多线程的应用

    1.进程 就像我们任务管理器里面运行的进程 进程(Process)是Windows系统中的一个基本概念,它包含着一个运行程序所需要的资源.一个正在运行的应用程序在操作系统中被视为一个进程,进程可以包括 ...

  4. 启动Process实现多任务

    from multiprocessing import Process import time '''multiprocessing模块1.跨平台的多进程模块2.提供了一个Process类的实例代表一 ...

  5. Centos 更改语言设置为中文

    说明 自己装系统时一般都可以自定义选择系统语言.可是云端服务器一般都是安装好的镜像,默认系统语言为英文,对于初学者可能还会有搞不懂的计算机词汇.这里简单说一下centos7怎么修改系统语言为中文. 修 ...

  6. bootstrapTable 分页插件

    前端: @{ ViewBag.Title = "BootstrapTable 入门"; Layout = null; } <!-- 引入bootstrap样式 --> ...

  7. C++11下的关键字

    STL类:stack,queue,deque,priority_queue,map,set,multiset,bitset,vector 函数类:min,max,swap,sqrt,log,rever ...

  8. 基于mybatis-plus的代码生成

    基于mybatis-plus的代码生成 前言 随着敏捷开发模式的推广,伴着日益增长的需求,日常工作中我们越来越注重效率和便捷性.今天我们就来探讨下如何自动生成代码,准确地说是如何依赖数据库生成我们的e ...

  9. 多图上传控制器及模型代码(2)thinkphp5+layui实现多图上传保存到数据库,可以实现图片自由排序,自由删除。

    公共css代码 <style> .layui-upload-img { width: 90px; height: 90px; margin: 0; } .pic-more { width: ...

  10. 关于命令ride.py打不开RF,而是打开pycharm编辑器问题解决思路

    自从用RF工具做自动化测试以来,碰到过三次标题中的问题.头两次问别人解决了,第三次就自己动手解决,并记录下来. 第一次碰到这个问题,以为问题很小,没有放在心上,同事帮忙弄出来了. 别人帮忙弄的,记忆力 ...