ActiveMQ的发布者/订阅者模型示例
ActiveMQ的发布者/订阅者模型入门示例
(1)下载安装activemq,启动activeMQ。
详细步骤参考博客:http://www.cnblogs.com/DFX339/p/9050878.html
(2)创建maven项目,java项目或者web项目都可以。
项目源码下载地址:https://github.com/DFX339/activeMQ_demo.git
目录结构如下:(queue包下的是activemq队列模型的入门示例,需要的可以参考 http://www.cnblogs.com/DFX339/p/9050950.html)
需要编写的文件:MQProducer.java Listener01.java MQConsumer01.java Listener02.java MQConsumer02.java pom.xml

消息发布者的定义: MQProducer.java
主要步骤:
/**
* 1.创建连接工厂
* 2.创建连接实例
* 3、启动连接
* 4、创建session创建接收或发送的线程实例(创建session的时候定义是否要启用事务,
* 且事务类型是Auto_ACKNOWLEDGE也就是消费者成功在Listern中获得消息返回时,会话自动确定用户收到消息)
* 5、创建队列(消息发送的目的地)
* 6、创建消息发送者
* 7、创建消息
* 8、发送消息
* 9、session.commit();提交千万不要忘记了
*/
代码如下:
package cn.dfx.activeMQ_demo.topic; 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.ActiveMQConnectionFactory; /**
* 订阅消息的发送消息方
* @author Administrator
*
*/
public class MQProducer { public static void main(String[] args){ /**
* 1.创建连接工厂
* 2.创建连接实例
* 3、启动连接
* 4、创建session创建接收或发送的线程实例(创建session的时候定义是否要启用事务,
* 且事务类型是Auto_ACKNOWLEDGE也就是消费者成功在Listern中获得消息返回时,会话自动确定用户收到消息)
* 5、创建队列(消息发送的目的地)
* 6、创建消息发送者
* 7、创建消息
* 8、发送消息
* 9、session.commit();提交千万不要忘记了
*/ ConnectionFactory connFactory = null;
Connection conn = null;
Session session = null;
Destination destination = null; //连接参数定义: 用户名 密码 url
String name = "system";
String password = "manager";
String url = "failover://tcp://localhost:61616"; System.out.println("消息发布者开始发布消息了……");
try{ //创建连接工厂
//这里的连接参数可以使用常量:Constants.MQ_NAME, Constants.MQ_PASSWORD, Constants.MQ_BROKETURL
connFactory = new ActiveMQConnectionFactory(name,password,url); //通过连接工厂创建连接实例
conn = connFactory.createConnection(); //启动连接
conn.start(); //4、创建session创建接收或发送的线程实例(创建session的时候定义是否要启用事务,且事务类型是Auto_ACKNOWLEDGE也就是消费者成功在Listern中获得消息返回时,会话自动确定用户收到消息)
//也可以使用:session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
session = conn.createSession(true, Session.AUTO_ACKNOWLEDGE); //创建队列,也就是消息发送的目的地
destination = session.createTopic("FirstTopic"); //创建消息发布者
MessageProducer messageProducer = session.createProducer(destination); //创建需要发送的消息
TextMessage textMessage = session.createTextMessage();
textMessage.setText("Hello,broadcast message NO.1!"); //发送消息
messageProducer.send(textMessage); //一定要记得这个,提交呀,
session.commit(); System.out.println("消息发布者:"+textMessage.getText()); }catch(JMSException e){
e.printStackTrace();
} finally { //关闭连接
if (conn != null) {
try {
conn.close();
} catch (JMSException e) {
e.printStackTrace();
}
} } }
}
消息订阅者01的定义: MQConsumer01.java
主要步骤:
/**
* 1.创建连接工厂
* 2.创建连接实例
* 3、启动连接
* 4、 创建接收或发送的线程实例(消费者就不需要开启事务了)
* 5、创建队列(消息发送的目的地)
* 6、创建消息接收者
* 7、注册消息监听
*/
代码示例:
package cn.dfx.activeMQ_demo.topic; import java.io.IOException; import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.Session;
import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnectionFactory; /**
* 订阅消息的消息接收方01
* @author Administrator
*
*/
public class MQConsumer01 { public static void main(String[] args) throws IOException{ /**
* 1.创建连接工厂
* 2.创建连接实例
* 3、启动连接
* 4、 创建接收或发送的线程实例(消费者就不需要开启事务了)
* 5、创建队列(消息发送的目的地)
* 6、创建消息接收者
* 7、注册消息监听
*/ ConnectionFactory connFactory = null;
Connection conn = null;
Session session = null;
Destination destination = null; //创建连接工厂需要的参数
String name = "system";
String password = "manager";
String url = "failover://tcp://localhost:61616"; try{ //创建连接工厂
connFactory = new ActiveMQConnectionFactory(name,password,url); //创建连接实例
conn = connFactory.createConnection(); //启动连接
conn.start(); //创建session(创建接收或发送的线程实例(消费者就不需要开启事务了))
session = conn.createSession(true, Session.AUTO_ACKNOWLEDGE); //创建消息目的地(消费者从这里读取消息)
destination = session.createTopic("FirstTopic"); //创建消费者
MessageConsumer messageConsumer = session.createConsumer(destination); //消费者读取消息,监听消息
messageConsumer.setMessageListener(new Listener01()); System.out.println("订阅者01已经准备好接收消息!"); // //8、程序等待接收用户消息
// System.in.read();
// //9、关闭资源
// messageConsumer.close();
// session.close();
// conn.close(); }catch(JMSException e){
e.printStackTrace();
}
}
}
消息订阅者01的监听器的编写: Listener01.java
package cn.dfx.activeMQ_demo.topic; import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage; /**
* 消息订阅 消息接收方的订阅者01的监听器
* @author Administrator
*
*/
public class Listener01 implements MessageListener { @Override
public void onMessage(Message message) { try{
System.out.println("订阅者01接收到的消息为:"+((TextMessage) message).getText());
}catch(JMSException e){
e.printStackTrace();
} } }
消息订阅者02的定义: MQConsumer02.java
主要步骤:
/**
* 1.创建连接工厂
* 2.创建连接实例
* 3、启动连接
* 4、创建接收或发送的线程实例(消费者就不需要开启事务了)
* 5、创建队列(消息发送的目的地)
* 6、创建消息接收者
* 7、注册消息监听
*/
代码示例:
package cn.dfx.activeMQ_demo.topic; import java.io.IOException; import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.Session;
import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnectionFactory; /**
* 订阅消息的消息接收方02
* @author Administrator
*
*/
public class MQConsumer02 { public static void main(String[] args) throws IOException{ /**
* 1.创建连接工厂
* 2.创建连接实例
* 3、启动连接
* 4、 创建接收或发送的线程实例(消费者就不需要开启事务了)
* 5、创建队列(消息发送的目的地)
* 6、创建消息接收者
* 7、注册消息监听
*/ ConnectionFactory connFactory = null;
Connection conn = null;
Session session = null;
Destination destination = null; //创建连接工厂需要的参数
String name = "system";
String password = "manager";
String url = "failover://tcp://localhost:61616"; try{ //创建连接工厂
connFactory = new ActiveMQConnectionFactory(name,password,url); //创建连接实例
conn = connFactory.createConnection(); //启动连接
conn.start(); //创建session(创建接收或发送的线程实例(消费者就不需要开启事务了))
session = conn.createSession(true, Session.AUTO_ACKNOWLEDGE); //创建消息目的地(消费者从这里读取消息)
destination = session.createTopic("FirstTopic"); //创建消费者
MessageConsumer messageConsumer = session.createConsumer(destination); //消费者读取消息,监听消息
messageConsumer.setMessageListener(new Listener01()); System.out.println("订阅者02已经准备好接收消息!"); }catch(JMSException e){
e.printStackTrace();
}
}
}
消息订阅者02的监听器的编写: Listener02.java
package cn.dfx.activeMQ_demo.topic; import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage; /**
* 消息订阅 消息接收方的订阅者02的监听器
* @author Administrator
*
*/
public class Listener01 implements MessageListener { @Override
public void onMessage(Message message) { try{
System.out.println("订阅者02接收到的消息为:"+((TextMessage) message).getText());
}catch(JMSException e){
e.printStackTrace();
} } }
(3)测试步骤
1、先启动activemq
启动方法:找到activemq安装目录,进入bin目录,双击activemq.bat
启动结果:

2、启动消息订阅者01
启动方法: 打开MQConsumer01.java --> 右击 --> Run as --> java Application
启动结果:

3、启动消息订阅者02
启动方法: 打开MQConsumer02.java --> 右击 --> Run as --> java Application
启动结果:

4、启动消息发布者
启动方法: 打开MQProducer.java --> 右击 --> Run as --> java Application
启动结果:(订阅者会自动读取消息,可以切换控制台查询读取情况)

订阅者01读取消息后:

订阅者02读取消息后:

ActiveMQ的发布者/订阅者模型示例的更多相关文章
- (三)ActiveMQ之发布- 订阅消息模式实现
一.概念 发布者/订阅者模型支持向一个特定的消息主题发布消息.0或多个订阅者可能对接收来自特定消息主题的消息感兴趣.在这种模型下,发布者和订阅者彼此不知道对方.这种模式好比是匿名公告板.这种模式被概括 ...
- ACtiveMQ中间件-发布订阅模式
前言:ActiveMQ学习心得 1.MQ是什么 MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过读写出入队列的消息(针对应用程序的数据)来通信, ...
- python中使用redis发布订阅者模型
redis发布订阅者模型: Redis提供了发布订阅功能,可以用于消息的传输,Redis的发布订阅机制包括三个部分,发布者,订阅者和Channel.发布者和订阅者都是Redis客户端,Channel则 ...
- vue双向绑定(数据劫持+发布者-订阅者模式)
参考文献:https://www.cnblogs.com/libin-1/p/6893712.html 实现mvvm主要包含两个方面,数据变化更新视图,视图变化更新数据. 关键点在于data如何更新v ...
- 【ActiveMQ】- 发布/订阅模式
publish/subscribe 特点:A发送的消息可以被所有监听A的对象的接收,就好比学校的广播,所有的学生都可以收听校园广播信息. 消息生产者: package com.zhiwei.advan ...
- EventBus事件总线框架(发布者/订阅者模式,观察者模式)
一. android应用内消息传递的方式: 1. handler方式-----------------不同线程间传递消息. 2. Interface接口回调方式-------任意两个对象. 3. In ...
- C#事件支持发布者/订阅者模式(观察者模式)
C#事件支持发布者/订阅者模式,发布者将事件通知给订阅者,而订阅者在事件发生时调用已经注册好的事件处理函数. public delegate void delUpdate(); //委 ...
- [js高手之路]设计模式系列课程-发布者,订阅者重构购物车
发布者订阅者模式,是一种很常见的模式,比如: 一.买卖房子 生活中的买房,卖房,中介就构成了一个发布订阅者模式,买房的人,一般需要的是房源,价格,使用面积等信息,他充当了订阅者的角色 中介拿到卖主的房 ...
- lvs基本概念、调度方法、ipvsadm命令及nat模型示例
LVS类型: NAT:-->(DNAT) DR TUN FULLNAT LVS的常见名词解释 CIP<-->VIP--DIP<-->RIP Direct Routing: ...
随机推荐
- 用basicTrendline画一元线性回归直线的置信区间
感慨统计学都还给老师了..恶补! R安装包的时候貌似需要用管理员权限启动,否则安装不了,国内镜像卡得渣渣,还是国外镜像真香~选择hongkong就好了. install.packages(" ...
- java8新特性(二)_lambda表达式
最近一直找java8相关新特性的文章,发现都太没有一个连贯性,毕竟大家写博客肯定都有自己的侧重点,这里找到一本书,专门介绍java8新特性的,感觉大家可以看看<写给大忙人看的JavaSE8> ...
- 数据结构(C语言版)-第3章 栈和队列
3.1 栈和队列的定义和特点3.2 案例引入3.3 栈的表示和操作的实现3.4 栈与递归3.5 队列的的表示和操作的实现3.6 案例分析与实现 基本操作有入栈.出栈.读栈顶元素值.建栈.判断栈满.栈空 ...
- English trip EM2-LP-3A Gifts Teacher:Patrick
课上内容(Lesson) 词汇(Key Word ) Identify vt. 确定:识别:使参与:把…看成一样 objects n. 物体(object的复数):目标 # UFO = ...
- java.lang.NoClassDefFoundError: org/springframework/web/context/WebApplicationContext
一.NoClassDefFoundError与ClassNotFoundException NoClassDefFoundError错误的发生,是因为Java虚拟机在编译时能找到合适的类,而在运行时不 ...
- codeforces 578a//A Problem about Polyline// Codeforces Round #320 (Div. 1)
题意:一个等腰直角三角形一样的周期函数(只有x+轴),经过给定的点(a,b),并且半周期为X,使X尽量大,问X最大为多少? 如果a=b,结果就为b 如果a<b无解. 否则,b/(2*k*x-a) ...
- caffe---mnist数据集训练与测试
1.数据.mnist_test_lmdb和mnist_train_lmdb数据 2.路径. (1)修改lenet_train_test.prototxt文件,训练和测试两处 source: " ...
- Spring Batch 介绍
在企业应用的关键环境中,通常有需要很多应用来来处理大量的应用.这商业操作包括了自动化,并且负责的处理程序来对大量数据进行高效的处理,通常这些程序不需要人工进行干预.这些事件包括有基于时间周期产生的操作 ...
- session一二事
Session即回话,指一种持续性的.双向的连接.Session和Cookie在本质上没有什么区别,都是针对HTTP协议的局限性而提出的一种保持客户端和服务器间保持会话连接状态的机制. Session ...
- 卸载WPS后怎么WORD的图标还是WPS
在电脑中选择使用Microsoft Office并将之前安装的WPS Office办公软件卸载了.但是卸载之后发现电脑系统中的Word.Excel等文件无法正常显示图标.在这样的情况下,我们应该如何解 ...