ActiveMQ第一个示例
首先先安装ActiveMQ:https://www.cnblogs.com/hejianliang/p/9149590.html
创建Java项目,把 activemq-all-5.15.4.jar 包导入到项目。
本次案例主要有两个角色,分别是 新闻发布者(NewsPublisher)、新闻订阅者(NewsSubscriber);发布者相当于 生产者,负责生产消息,订阅者相当于 消费者,负责接收消息。
新闻发布者(NewsPublisher)
package edu.activemq.publisher; import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory; /**
* 新闻发布者(生产者)
* @author Administrator
*
*/
public class NewsPublisher { /**
* ActiveMQ连接用户名
*/
private static final String USERNAME = ActiveMQConnection.DEFAULT_USER; /**
* ActiveMQ连接密码
*/
private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD; /**
* ActiveMQ连接地址
*/
private static final String BROKER_URL = ActiveMQConnection.DEFAULT_BROKER_URL; /**
* 消息队列名称
*/
private static final String QUEUE_NAME = "MY_QUEUE"; /**
* 发布数量
*/
private static final Integer SEND_NUMBER = 5000; /**
* 发布新闻
*/
public static void main(String[] args) {
// 声明连接工厂
ConnectionFactory connectionFactory; // 声明连接
Connection connection = null; // 声明会话,接收或者发送信息的线程
Session session; // 声明消息的目的地
Destination destination; // 声明消息生产者
MessageProducer messageProducer; try {
// 实例化连接工厂
connectionFactory = new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKER_URL); // 通过连接工厂创建 连接
connection = connectionFactory.createConnection(); // 启动连接
connection.start(); // 创建session 参数1:开启事物 参数2:消息确认方式
session = connection.createSession(true, Session.AUTO_ACKNOWLEDGE); // 创建消息队列
destination = session.createQueue(QUEUE_NAME); // 创建消息生产者
messageProducer = session.createProducer(destination); // 发送消息
sendMessage(session, messageProducer); // 提交事务
session.commit();
} catch (Exception e) {
System.out.println("发布新闻失败.");
e.printStackTrace();
} finally {
// 关闭资源
if (null != connection) {
try {
connection.close();
} catch (Exception e) {
System.out.println("关闭资源失败.");
e.printStackTrace();
}
}
}
} /**
* 发送消息
* @param session
* @param messageProducer
*/
private static void sendMessage(Session session, MessageProducer messageProducer) {
// 声明消息对象
TextMessage textMessage; try {
for (int i = 0; i <= SEND_NUMBER; i++) {
// 创建消息
textMessage = session.createTextMessage("当前发送的新闻xxx, 编号为: " + i); // 发送消息
messageProducer.send(textMessage);
}
} catch (Exception e) {
System.out.println("发送新闻消息失败.");
e.printStackTrace();
}
} }
新闻订阅者(NewsSubscriber)
package edu.activemq.subscriber; import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.MessageConsumer;
import javax.jms.Session; import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory; import edu.activemq.listener.NewsSubscriberListener; /**
* 新闻订阅者(消费者)
* @author Administrator
*
*/
public class NewsSubscriber { /**
* ActiveMQ连接用户名
*/
private static final String USERNAME = ActiveMQConnection.DEFAULT_USER; /**
* ActiveMQ连接密码
*/
private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD; /**
* ActiveMQ连接地址
*/
private static final String BROKER_URL = ActiveMQConnection.DEFAULT_BROKER_URL; /**
* 消息队列名称
*/
private static final String QUEUE_NAME = "MY_QUEUE"; public static void main(String[] args) {
// 声明连接工厂
ConnectionFactory connectionFactory; // 连接
Connection connection = null; // 会话
Session session; // 消息目的地
Destination destination; // 消息的消费者
MessageConsumer messageConsumer; // 实例化连接工厂
connectionFactory = new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKER_URL);
try {
// 获取连接
connection = connectionFactory.createConnection();
// 启动连接
connection.start(); // 获取Session
session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); // 创建连接的消息队列
destination = session.createQueue(QUEUE_NAME); // 创建消息的消费者
messageConsumer = session.createConsumer(destination); // 注册消息监听
messageConsumer.setMessageListener(new NewsSubscriberListener()); } catch (Exception e) {
e.printStackTrace();
}
} }
新闻监听器(NewsSubscriberListener)
package edu.activemq.listener; import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage; /**
* 新闻监听器
* @author Administrator
*
*/
public class NewsSubscriberListener implements MessageListener { @Override
public void onMessage(Message message) {
try {
// 创建文本消息对象
TextMessage textMessage = (TextMessage) message; // 输出监听到的消息
System.out.println("NewsSubscriberListener 监听到的消息: " + textMessage.getText());
} catch (Exception e) {
e.printStackTrace();
}
} }
新闻发布者(NewsPublisher):负责生产消息,将消息发送到队列里面去。
新闻订阅者(NewsSubscriber):负责消费消息,从消息队列里面取出消息。
新闻监听器(NewsSubscriberListener):新闻订阅者的一个监听器,辅助订阅者监听队列的消息。
运行结果:
发布新闻:

订阅者消费:


运行后,队列里的消息已经被订阅者消费了。
ActiveMQ第一个示例的更多相关文章
- 创建ArcGIS API for JavaScript的第一个示例程序
原文:创建ArcGIS API for JavaScript的第一个示例程序 在上一篇博客中已经介绍了如何搭建ArcGIS API for JavaScript开发环境,如果您还没有搭建好开发环境的话 ...
- SkylineGlobe TerraExplorer Pro 7.0 Web 控件版 第一行示例代码
SkylineGlobe TerraExplorer Pro 7.0 是原生的64位应用程序,在Web端用插件方式开发的第一行示例代码如下: 常规代码,需要IE64位: <!DOCTYPE ht ...
- ActiveMQ的P2P示例
ActiveMQ的P2P示例(点对点通信) (1)下载安装activemq,启动activeMQ. 详细步骤参考博客:http://www.cnblogs.com/DFX339/p/9050878.h ...
- Kotlin协程第一个示例剖析及Kotlin线程使用技巧
Kotlin协程第一个示例剖析: 上一次https://www.cnblogs.com/webor2006/p/11712521.html已经对Kotlin中的协程有了理论化的了解了,这次则用代码来直 ...
- [转] VS2015中跑OpenGL红宝书第八版的第一章示例代码,运行
Ori Article Link OpenGL的东西快忘光了,把角落的第八版红宝书拿出来复习一下 从书中的地址下了个示例代码结果新系统(Win10+VS2015)各种跑不起来,懊恼之后在网上疯狂搜索资 ...
- ActiveMQ入门操作示例
1. Queue 1.1 Producer 生产者:生产消息,发送端. 把jar包添加到工程中. 第一步:创建ConnectionFactory对象,需要指定服务端ip及端口号. 第二步:使用Conn ...
- Java改写重构第2版第一个示例
写在前面 <重构:改善既有代码的设计>是一本经典的软件工程必读书籍.作者马丁·福勒强调重构技术是以微小的步伐修改程序. 但是,从国内的情况来而论,"重构"的概念表里分离 ...
- ActiveMQ第一弹:安装与运行
ActiveMQ使用java写的,所以天然跨平台,windows,各种类Unix系统都可运行,只需要下载对应的分发包即可.当前AciveMQ的最新版本是5.9.0.我目前在自己机子上安装的版本是5.8 ...
- ActiveMQ queue 代码示例
生产者: package com.111.activemq; import javax.jms.Connection; import javax.jms.ConnectionFactory; impo ...
随机推荐
- 总结一下,selenium 自动化流程如下
自动化程序调用Selenium 客户端库函数(比如点击按钮元素) 客户端库会发送Selenium 命令 给浏览器的驱动程序 浏览器驱动程序接收到命令后 ,驱动浏览器去执行命令 浏览器执行命令 浏览器驱 ...
- 极简 Node.js 入门 - 4.3 可读流
极简 Node.js 入门系列教程:https://www.yuque.com/sunluyong/node 本文更佳阅读体验:https://www.yuque.com/sunluyong/node ...
- linux中重启网卡后网络不通(NetworkManager篇)
1.问题描述 RHEL7.6系统,使用nmcli绑定双网卡后,在使用以下命令重启network服务后主机网络异常,导致无法通过ssh远程登录系统. systemctl restart network ...
- 034 01 Android 零基础入门 01 Java基础语法 04 Java流程控制之选择结构 01 流程控制概述
034 01 Android 零基础入门 01 Java基础语法 04 Java流程控制之选择结构 01 流程控制概述 本文知识点:Java中的流程控制相关概念的认识 三大流程控制语句结构的简介 顺序 ...
- MySQL数据库入侵及防御方法
来自:http://blog.51cto.com/simeon/1981572 作者介绍 陈小兵,高级工程师,具有丰富的信息系统项目经验及18年以上网络安全经验,现主要从事网络安全及数据库技术研究工作 ...
- NOIP提高组2013 D2T3 【华容道】
某王 老师给我们考了一场noip2013的真题...心态爆炸! 题目大意: 有一个n*m的棋盘,每个格子上都有一个棋子,有些格子上的棋子能够移动(可移动的棋子是固定的),棋盘中有一个格子是空的,仍何 ...
- CRF基础知识以及如何实现Learning,Inference
CRF:Conditional Random Field,即条件随机场. 首先介绍一下基础背景知识.机器学习中的分类问题可以分为硬分类和软分类.硬分类常见的模型有SVM.PLA.LDA等.SVM可以称 ...
- background-size 详解
backgroun-size:cover; .是按照等比缩放铺满整个区域.主要用于图片比div小的时候,将图片按照某一边的比例扩大以填充整个div背景. .优点:图片不会被拉升,且实用于div长度和宽 ...
- JS关闭chorme页面
百度到的很多答案都失效了,这是收集一位博主的(https://www.jianshu.com/p/9dc2752194b8),目前可以使用. 代价是打开一个空白页面,能实现无提示关闭当前页面.不需要是 ...
- 【C/C++编程入门学习】C语言结构体硬核玩法分享,一切皆是数据!
前言 对于结构体的应用太多了,今天这篇文章我主要为大家总结平时关于结构体的一些独特硬核小技巧,对于结构体更多优秀的编程表现,如果你对结构体的基础知识还不具备的话得回头看一下专栏教程或者自己找本书籍学习 ...