首先先安装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第一个示例的更多相关文章

  1. 创建ArcGIS API for JavaScript的第一个示例程序

    原文:创建ArcGIS API for JavaScript的第一个示例程序 在上一篇博客中已经介绍了如何搭建ArcGIS API for JavaScript开发环境,如果您还没有搭建好开发环境的话 ...

  2. SkylineGlobe TerraExplorer Pro 7.0 Web 控件版 第一行示例代码

    SkylineGlobe TerraExplorer Pro 7.0 是原生的64位应用程序,在Web端用插件方式开发的第一行示例代码如下: 常规代码,需要IE64位: <!DOCTYPE ht ...

  3. ActiveMQ的P2P示例

    ActiveMQ的P2P示例(点对点通信) (1)下载安装activemq,启动activeMQ. 详细步骤参考博客:http://www.cnblogs.com/DFX339/p/9050878.h ...

  4. Kotlin协程第一个示例剖析及Kotlin线程使用技巧

    Kotlin协程第一个示例剖析: 上一次https://www.cnblogs.com/webor2006/p/11712521.html已经对Kotlin中的协程有了理论化的了解了,这次则用代码来直 ...

  5. [转] VS2015中跑OpenGL红宝书第八版的第一章示例代码,运行

    Ori Article Link OpenGL的东西快忘光了,把角落的第八版红宝书拿出来复习一下 从书中的地址下了个示例代码结果新系统(Win10+VS2015)各种跑不起来,懊恼之后在网上疯狂搜索资 ...

  6. ActiveMQ入门操作示例

    1. Queue 1.1 Producer 生产者:生产消息,发送端. 把jar包添加到工程中. 第一步:创建ConnectionFactory对象,需要指定服务端ip及端口号. 第二步:使用Conn ...

  7. Java改写重构第2版第一个示例

    写在前面 <重构:改善既有代码的设计>是一本经典的软件工程必读书籍.作者马丁·福勒强调重构技术是以微小的步伐修改程序. 但是,从国内的情况来而论,"重构"的概念表里分离 ...

  8. ActiveMQ第一弹:安装与运行

    ActiveMQ使用java写的,所以天然跨平台,windows,各种类Unix系统都可运行,只需要下载对应的分发包即可.当前AciveMQ的最新版本是5.9.0.我目前在自己机子上安装的版本是5.8 ...

  9. ActiveMQ queue 代码示例

    生产者: package com.111.activemq; import javax.jms.Connection; import javax.jms.ConnectionFactory; impo ...

随机推荐

  1. 关于window服务器中新建的普通用户无法登录远程桌面

    今天在公司服务器中为客户创建了一个普通用户 user5201351  并设置好了密码, 发给客户后,反映使用我们创建的用户不能通过远程桌面进行登录 查询资料后才知道,在windows中,需要将用户加入 ...

  2. C#设置装配加载选项

    NX在打开装配时,需要设置加载方式,如下图所示: 因此,当装配进行了拷贝之后,PART路径变化,再次用NX打开时,会报无法加载的错误.这时需要重新设置从搜索文件夹打开,再次保存之后,之后再按照保存打开 ...

  3. BTRsys1~2系列靶机渗透

    BTRsys系列靶机渗透 BTRsys1 端口发现加目录扫描. 发现目录:http://192.168.114.161/login.php 尝试弱密码失败,查看源代码. <script type ...

  4. Combine 框架,从0到1 —— 5.Combine 中的 Subjects

    本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 5.Combine 中的 Subjects. 内容概览 前言 PassthroughSubject C ...

  5. iNeuOS工业互联平台,机床&PLC硬件网关与平台无缝对接,进行数据交互

    目       录 1.      概述... 2 2.      平台演示... 2 3.      硬件网关的基本操作... 3 3.1           数据采集... 3 3.2       ...

  6. 基础篇:详解锁原理,volatile+cas、synchronized的底层实现

    目录 1 锁的分类 2 synchronized底层原理 3 Object的wait和notify方法原理 4 jvm对synchronized的优化 5 CAS的底层原理 6 CAS同步操作的问题 ...

  7. 微服务实战系列(十)-网关高可用之中间件Keepalived

    1.场景描述 因为要做网关的高可用,用到了keepalived+nginx,来保证nginx的高可用,如下图: 安装了keepavlived,走了一些弯路,记录下吧,nginx的安装就不多说了,博客已 ...

  8. 基于GAN的特征抽取 Feature Extraction by GAN

    InfoGAN 期望的是 input 的每一个维度都能表示输出数据的某种特征.但实际改变输入的一个特定维度取值,很难发现输出数据随之改变的规律. InfoGAN 就是想解决这个问题.在 GAN 结构以 ...

  9. 初识HTTP 图解 形象生动

    使用软件: 通信猫  请自行下载 使用平台: win7 360浏览器 当前PC连接的是无线网,所以第2步查看的是 无线局域网适配器上的IP地址

  10. 091 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 02 static关键字 01 static关键字(上)

    091 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 ...