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 ...
随机推荐
- PostGreSQL不同索引类型(btree & hash)的性能问题
在关系型数据库调优中,查询语句涉及到的索引类型是不得不考虑的一个问题.不同的类型的索引可能会适用不同类型的业务场景.这里我们所说的索引类型指的是访问方法(Access Method),至于从其他维度区 ...
- CSS3 新特性总结
1.边框 border-radius: 1-4 length|% / 1-4 length|%; 每个半径的四个值的顺序是:左上角,右上角,右下角,左下角.若省略左下角,和右上角相同,省略右下角,左上 ...
- 浅谈Java多线程
线程与进程 什么是进程? 当一个程序进入内存中运行起来它就变为一个进程.因此,进程就是一个处于运行状态的程序.同时进程具有独立功能,进程是操作系统进行资源分配和调度的独立单位. 什么是线程? 线程是进 ...
- python协程(yield、asyncio标准库、gevent第三方)、异步的实现
引言 同步:不同程序单元为了完成某个任务,在执行过程中需靠某种通信方式以协调一致,称这些程序单元是同步执行的. 例如购物系统中更新商品库存,需要用"行锁"作为通信信号,让不同的更新 ...
- 【FastDFS】小伙伴们说在CentOS 8服务器上搭建FastDFS环境总报错?
写在前面 在[冰河技术]微信公众号的[分布式存储]专题中,我们分别搭建了单节点FastDFS环境和高可用FastDFS集群环境.但是,之前的环境都是基于CentOS 6.8服务器进行搭建的.很多小伙伴 ...
- Ubuntu中卸载node和npm并重装
1.node 和 npm 卸载不干净 #apt-get 卸载 sudo apt-get remove --purge npm sudo apt-get remove --purge nodejs su ...
- RestTemplate get请求多参数 简单封装
使用RestTemplate发送get请求时,如果有多个参数拼接起来会比较麻烦,在此做个简单的封装 public static void main(String[] args) { Map<St ...
- linux(centos)环境下安装rabbitMq
1.由于rabbitMq是用Erlang语言写的,因此要先安装Erlang环境 下载Erlang :http://www.rabbitmq.com/releases/erlang/erlang-19. ...
- EF Entity Framework Core DBContext中文文档
Add(Object) 以添加状态开始跟踪给定的实体和任何其他尚未被跟踪的可访问实体,以便在调用SaveChanges()时将它们插入数据库.使用State设置单个实体的状态. Add<TEnt ...
- 一、Mysql(1)
数据库简介 人类在进化的过程中,创造了数字.文字.符号等来进行数据的记录,但是承受着认知能力和创造能力的提升,数据量越来越大,对于数据的记录和准确查找,成为了一个重大难题 计算机诞生后,数据开始在计算 ...