关闭

JMS&MQ,从入门到精通(六)

标签: activemqjms队列队列过滤器队列发送queue接口
794人阅读 评论(0) 收藏 举报
分类:
本篇我们来介绍一下activeMq的Queue的细节之处

 前面的例子中创建一个消息消费者使用的是:
 sesssion.createConsumer(destination)另外,还提供了另一种方式:
 sesssion.createConsumer(destination, selector)这里selector是一个字符串,用来过滤消息。也就是说,这种方式可以创建一个可以只
 接收特定消息的一个消费者Selector的格式是类似于SQL-92的一种语法,可以用来比较消息头信息和属性

思路

1.创建两个消费者,共同监听同一个Queue,但是它们的Selector不同
2.然后创建一个消息生产者,来发送多个消息

一个简单的实例

ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost");
Connection connection = factory.createConnection();
connection.start();

Queue queue = new ActiveMQQueue("testQueue");

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

MessageConsumer comsumerA = session.createConsumer(queue, "receiver = 'A'");
comsumerA.setMessageListener(new MessageListener(){
    public void onMessage(Message m) {
        try {
            System.out.println("ConsumerA get " + ((TextMessage) m).getText());
        } catch (JMSException e1) { }
    }
});

MessageConsumer comsumerB = session.createConsumer(queue, "receiver = 'B'");
comsumerB.setMessageListener(new MessageListener(){
    public void onMessage(Message m) {
        try {
            System.out.println("ConsumerB get " + ((TextMessage) m).getText());
        } catch (JMSException e) { }
    }
});

MessageProducer producer = session.createProducer(queue);
for(int i=0; i<10; i++) {
    String receiver = (i%3 == 0 ? "A" : "B");
    TextMessage message = session.createTextMessage("Message" + i + ", receiver:" + receiver);
    message.setStringProperty("receiver", receiver);
    producer.send(message );
}
/**
 结果如下:
 ConsumerA get Message0, receiver:A
 ConsumerB get Message1, receiver:B
 ConsumerB get Message2, receiver:B
 ConsumerA get Message3, receiver:A
 ConsumerB get Message4, receiver:B
 ConsumerB get Message5, receiver:B
 ConsumerA get Message6, receiver:A
 ConsumerB get Message7, receiver:B
 ConsumerB get Message8, receiver:B
 ConsumerA get Message9, receiver:A

 可以看出,消息消费者只会取走它自己感兴趣的消息。
 * */
不知道大家看出来了没,这里有点SQL-92标准的where查询的味道;

关键代码

TextMessage message = session.createTextMessage("Message" + i + ", receiver:" + receiver);
message.setStringProperty("receiver", receiver);
运行结果如下图;

这里写图片描述

下篇将结合本篇的精华之处,做一个复杂一点的实例,前方高能!!!
0
0
查看评论

ActiveMQ从入门到精通(三)

这是ActiveMQ系列的最后一篇文章,主要是关于ActiveMQ集群,这里采用的方式是:Zookeeper+LevelDB+ActiveMQ。前面2篇博客地址如下:《ActiveMQ从入门到精通(一)》、《ActiveMQ从入门到精通(二)》。 利用Zookeeper实现ActiveMQ的高...
  • jek123456
  • jek123456
  • 2017-05-19 09:36
  • 643

JMS&MQ,从入门到精通(二)

上一篇,我们介绍了jms&mq的一对一的消息传输与消息处理,本章节我们再实现,2个消费者共同监听一个Queue,然后循环给这 个Queue中发送多个消息,我们依然采用ActiveMQ来实现这个案例 1个队列多个监听者场景如下图: 实现思路new 一个queue,启动2个监听者对这个queue...
  • u013410747
  • u013410747
  • 2017-04-27 16:48
  • 642

MQ的入门指南

消息队列(Message Queue,简称 MQ)是阿里巴巴集团中间件技术部自主研发的专业消息中间件。 也就是说他只是一个中间商,我们将消息提交到阿里云上面,然后由阿里云的MQ组件给我们将消息分发。 实现逻辑: 我们通过accessId,secretKey和mnsEndpoint来建立与阿里云的连接...
  • qq_33774822
  • qq_33774822
  • 2017-04-22 17:09
  • 612

JMS&MQ,从入门到精通(六)

本篇我们来介绍一下activeMq的Queue的细节之处 前面的例子中创建一个消息消费者使用的是: sesssion.createConsumer(destination)另外,还提供了另一种方式: sesssion.createConsumer(destination, selector)这里...
  • u013410747
  • u013410747
  • 2017-04-28 15:50
  • 794

ActiveMQ 入门

入门: https://www.cnblogs.com/Sunnor/p/6230847.html ActiveMQ可以发送的数据类型:https://www.cnblogs.com/dennisit/p/4551795.html
  • qice675563721
  • qice675563721
  • 2018-01-30 16:00
  • 11

ORACLE从入门到精通 明日科技编著 清华大学出版社

http://pan.baidu.com/s/1gePoRAV
  • ggkmskj
  • ggkmskj
  • 2017-06-07 17:04
  • 1139

SQL SERVER-2008从入门到精通pdf

下载地址:网盘下载 内容要点 编辑 SQL Server 2008是Windows Server的最新版本,它推出了许多新的特性和关键性的改进,是至今为止最强大和最全面的SQL Server版本。本书详细介绍SQL Server 2008中的重要新增功能和增强特性。 ...
  • cf406061841
  • cf406061841
  • 2017-06-04 23:24
  • 1088

ActiveMQ视频教程

  • 2017-03-24 17:14
  • 48B
  • 下载

ActiveMQ入门实例

http://www.cnblogs.com/xwdreamer/archive/2012/02/21/2360818.html 1.下载ActiveMQ 去官方网站下载:http://activemq.apache.org/ 2.运行ActiveMQ 解压缩apache...
  • guolong1983811
  • guolong1983811
  • 2017-01-22 21:48
  • 451

C#从入门到精通学习笔记——(1)

一、概述 1.C#语言特性: 2.C#与.net框架的关系: 3.VS应用
  • Memory_sand
  • Memory_sand
  • 2017-04-04 16:26
  • 325
    个人资料
    • 访问:296374次
    • 积分:4219
    • 等级:
    • 排名:第8603名
    • 原创:148篇
    • 转载:8篇
    • 译文:0篇
    • 评论:56条
    博客专栏