【ActiveMQ入门-4】ActiveMQ学习-异步接收
1. 一个生产者/发布者:可以向多个目的地发送消息;

1. Publisher.java :创建1个生产者和4个主题,遍历4个主题,生产者依次向4个主题中发送Message,共发送5次;
生产者:


Publisher.java
package com.ll.activemq;import javax.jms.Connection;import javax.jms.ConnectionFactory;import javax.jms.Destination;import javax.jms.JMSException;import javax.jms.MapMessage;import javax.jms.Message;import javax.jms.MessageProducer;import javax.jms.Session;import org.apache.activemq.ActiveMQConnectionFactory;import org.apache.activemq.command.ActiveMQMapMessage;public class Publisher {private ConnectionFactory factory;private Connection connection = null;private Session session;private String brokerURL = "tcp://localhost:61616";private MessageProducer producer;private Destination[] destinations;/*** 构造函数 创建连接、创建生产者** @throws JMSException*/public Publisher() throws JMSException {factory = new ActiveMQConnectionFactory(brokerURL);connection = factory.createConnection();try {connection.start();} catch (JMSException jmse) {connection.close();throw jmse;}session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);producer = session.createProducer(null);}/*** 设置目的地** @param stocks* :主题名列表* @throws JMSException*/protected void setTopics(String[] stocks) throws JMSException {destinations = new Destination[stocks.length];for (int i = 0; i < stocks.length; i++) {destinations[i] = session.createTopic("STOCKS." + stocks[i]);}}/*** 创建消息** @param stock* :主题名* @param session* @return* @throws JMSException*/protected Message createStockMessage(String stock, Session session)throws JMSException {MapMessage message = session.createMapMessage();message.setString("stock", stock);message.setDouble("price", 1.00);message.setDouble("offer", 0.01);message.setBoolean("up", true);return message;}/*** 发送消息* 遍历所有主题(目的地),向每个目的地分别发送一个MapMessage* @param stocks* :主题名* @throws JMSException*/protected void sendMessage(String[] stocks) throws JMSException {//遍历所有主题for (int i = 0; i < stocks.length; i++) {// 创建消息Message message = createStockMessage(stocks[i], session);System.out.println("发送: "+ ((ActiveMQMapMessage) message).getContentMap()+ " on destination: " + destinations[i]);// 往目的地发送消息producer.send(destinations[i], message);}}public void close() throws JMSException {try {if (null != connection)connection.close();} catch (Exception e) {e.printStackTrace();}}public static void main(String[] argss) throws JMSException {String[] topics = { "MyTopic1", "MyTopic2", "MyTopic3", "MyTopic4" };Publisher publisher = new Publisher();publisher.setTopics(topics);//每隔1s发送一次消息,共发送5次消息for (int i = 0; i < 5; i++) {System.out.println("发布者第:" + i + " 次发布消息...");publisher.sendMessage(topics);try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}}publisher.close();}}
Consumer.java
package com.ll.activemq;import javax.jms.Connection;import javax.jms.Destination;import javax.jms.JMSException;import javax.jms.MessageConsumer;import javax.jms.Session;import org.apache.activemq.ActiveMQConnectionFactory;public class Consumer {private ActiveMQConnectionFactory factory;private String brokerURL = "tcp://localhost:61616";private Connection connection = null;private Session session;public Consumer() throws JMSException {factory = new ActiveMQConnectionFactory(brokerURL);connection = factory.createConnection();connection.start();session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);}public Session getSession() {return session;}public static void main(String[] args) throws JMSException {String[] topics = { "MyTopic1", "MyTopic2", "MyTopic3", "MyTopic4" };Consumer consumer = new Consumer();for (String stock : topics) {//创建目的地Destination destination = consumer.getSession().createTopic("STOCKS." + stock);//创建消费者MessageConsumer messageConsumer = consumer.getSession().createConsumer(destination);MessageConsumer messageConsumer2 = consumer.getSession().createConsumer(destination);//设置监听器messageConsumer.setMessageListener(new Listener());messageConsumer2.setMessageListener(new Listener());}}}
Listener.java
package com.ll.activemq;import java.text.DecimalFormat;import javax.jms.MapMessage;import javax.jms.Message;import javax.jms.MessageListener;public class Listener implements MessageListener {/*** 异步接收* 当有消息时,就会触发该事件*/public void onMessage(Message message) {try {MapMessage map = (MapMessage)message;String stock = map.getString("stock");double price = map.getDouble("price");double offer = map.getDouble("offer");boolean up = map.getBoolean("up");DecimalFormat df = new DecimalFormat( "#,###,###,##0.00" );System.out.println("接收消息:"+stock + "\t" + df.format(price) + "\t" + df.format(offer) + "\t" + (up?"up":"down"));} catch (Exception e) {e.printStackTrace();}}}
延伸:
若是将上述程序中的 createTopic全部替换为createQueue,则运行结果如下:
附件列表
【ActiveMQ入门-4】ActiveMQ学习-异步接收的更多相关文章
- ActiveMQ入门之四--ActiveMQ持久化方式
消息持久性对于可靠消息传递来说应该是一种比较好的方法,有了消息持久化,即使发送者和接受者不是同时在线或者消息中心在发送者发送消息后宕机了,在消息中心重新启动后仍然可以将消息发送出去,如果把这种持久化和 ...
- ActiveMQ 入门和与 Spring 整合
ActiveMQ 入门演示 activemq 依赖 <dependency> <groupId>org.apache.activemq</groupId> < ...
- 【ActiveMQ入门-10】ActiveMQ学习-通配符+异步接收
通配符介绍: 一般情况下,我们使用层次结构的方式来组织队列,比如A.B.C.D,这样便于归类和管理. 我们也可以使用通配符来配置或是操作多个队列. 通配符有三个: . 用来分隔路径: * 用来匹 ...
- 【ActiveMQ入门-11】ActiveMQ学习-compositeDestination
概要: 前一章讲解了消费者如何通过通配符来匹配目的地,以实现一个消费者同时接收多个目的地的消息. 对于生产者来讲,可能存在下面的需求: 1. 同一条message可能要发送到多个Queue: 2. 同 ...
- ActiveMQ学习总结(2)——ActiveMQ入门实例教程
1.下载ActiveMQ 去官方网站下载:http://activemq.apache.org/ 2.运行ActiveMQ 解压缩apache-activemq-5.5.1-bin.zip,然后双击a ...
- 【ActiveMQ入门-5】ActiveMQ学习-消息持久性
ActiveMQ中的消息持久性 ActiveMQ很好的支持了消息的持久性(Persistence).消息持久性对于可靠消息传递来说应该是一种比较好的方法,有了消息持久化,即使发送者和接受者不是 ...
- Dubbo入门到精通学习笔记(十四):ActiveMQ集群的安装、配置、高可用测试,ActiveMQ高可用+负载均衡集群的安装、配置、高可用测试
文章目录 ActiveMQ 高可用集群安装.配置.高可用测试( ZooKeeper + LevelDB) ActiveMQ高可用+负载均衡集群的安装.配置.高可用测试 准备 正式开始 ActiveMQ ...
- Java消息中间件入门笔记 - ActiveMQ篇
入门 消息中间件带来的好处: 1)解耦:系统解耦 2)异步:异步执行 3)横向扩展 4)安全可靠 5)顺序保证 栗子: 通过服务调用让其它系统感知事件发生 系统之间高耦合 程序执行效率低 通过消息中间 ...
- 消息中间件-activemq入门(二)
上一节我们了解了JMS规范并且知道了JMS规范的良好实现者-activemq.今天我们就去了解一下activemq的使用.另外我们应该抱着目的去学习,别忘了我们为什么要使用消息中间件:解耦系统之间的联 ...
随机推荐
- 比较强大 优秀的开源框架 :Android图片加载与缓存:Android Glide 的用法
使用Android Glide,需要先下载Android Glide的库,Android Glide在github上的项目主页: https://github.com/bumptech/glide . ...
- DBLookupComboBox 的初始值
http://www.yourdelphi.com/topic_234544_e6b7.htm 试下在form的oncreate中加入 dblookupcombobox1.keyvalue:=tabl ...
- DevExpress v18.1新版亮点——WinForms篇(八)
用户界面套包DevExpress v18.1日前终于正式发布,本站将以连载的形式为大家介绍各版本新增内容.本文将介绍了DevExpress WinForms v18.1 的新功能,快来下载试用新版本! ...
- Linux->卸载Mysql方法总结
如何在Linux下卸载MySQL数据库呢? 下面总结.整理了一下Linux平台下卸载MySQL的方法. MySQL的安装主要有三种方式:二进制包安装(Using Generic Binaries).R ...
- zabbix监控系统的配置
一.zabbix介绍 zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案. zabbix能监视各种网络参数,保证服务器系统的安全运营:并提供灵活的通知机制以让系 ...
- Tesseract-OCR 训练教程(一)
实际应用中[font]替换为你自己的字体名,比如newfont.hehe等 1.根据tif生成box文件(位置宽高等信息)tesseract [font].font.exp0.tif [font].f ...
- 自定义页签logo
1.webpack.prod.conf new HtmlWebpackPlugin({ filename: process.env.NODE_ENV === 'testing' ? 'index.ht ...
- Java面试通关要点汇总整理【终极版】
简历篇 请自我介绍 请介绍项目 基础篇 基本功 面向对象的特征 final, finally, finalize 的区别 int 和 Integer 有什么区别 重载和重写的区别 抽象类和接口有什么区 ...
- opencv-原图基础上添加指定颜色
前言 项目中需要将某些区域使用不同的颜色表示出来,同时能够看到原图作为底色. 代码 #include "opencv2/highgui/highgui.hpp" #include ...
- 20分钟打造你的Bootstrap站点
来源:http://www.w3cplus.com/css/twitter-bootstrap-tutorial.html 特别声明:此篇文章由白牙根据Leon Revill的英文文章原名<Tw ...