ActiveMQ学习教程/2.简单示例
ActiveMQ学习教程(二)——简单示例
一。应用IDEA构建Maven项目
File-》New-》Module...-》Maven-》勾选-》选择-》Next -》
GroupId:com.jd.myMaven | ArtifactId:activeMQ | version:默认 -》Finish
项目构建成功!项目结构如下所示:
二。创建生产者类,模拟生产者发消息
Step1:java/activemq/JMSProducer.java
package activemq; import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
import org.apache.activemq.command.ActiveMQMapMessage; import javax.jms.*;
import java.util.Map; /**
* 消息生产者
*/
public class JMSProducer {
private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;//默认的连接用户名
private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;//默认的连接密码
private static final String BROKERURL = ActiveMQConnection.DEFAULT_BROKER_URL;//默认的连接地址
private static final int SENDNUM = 2;//发送的消息数量 public static void main(String[] args) {
ConnectionFactory connectionFactory = null;//连接工厂
Connection connection = null;//连接
Session session = null;//会话,接受或者发送消息的线程
Destination destination = null;//消息的目的地
MessageProducer messageProducer = null;//消息的生产者
//实例化连接工厂(指定连接用户名|密码|连接地址)
connectionFactory = new ActiveMQConnectionFactory(JMSProducer.USERNAME, JMSProducer.PASSWORD, JMSProducer.BROKERURL);
try {
connection = connectionFactory.createConnection();//通过连接工厂获取连接
connection.start();//启动连接
session = connection.createSession(true, Session.AUTO_ACKNOWLEDGE);//创建session
destination = session.createQueue("TestQueue");//创建消息队列
messageProducer = session.createProducer(destination);//创建消息生产者
sendMessage(session, messageProducer);//发送消息
session.commit();
} catch (Exception e) {
e.printStackTrace();
} finally {
if (connection != null) {
try {
connection.close();
} catch (JMSException e) {
e.printStackTrace();
}
}
} } //发送消息
private static void sendMessage(Session session, MessageProducer messageProducer) {
try {
//创建消息Map<key,value>
MapMessage message = session.createMapMessage();
message.setString("userName", "syf");
message.setInt("age", 30);
message.setDouble("salary", 1000);
message.setBoolean("isGirl", true);
System.out.println("Sending:" + ((ActiveMQMapMessage)message).getContentMap());
//发送消息
messageProducer.send(message);
} catch (JMSException e) {
e.printStackTrace();
}
}
}
Step2:启动ActiveMQ,运行生产者类,模拟生产消息
控制台显示:
Sending:{isGirl=true, userName=syf, salary=1000.0, age=30}
打开浏览器,访问activeMQ监控画面 http://127.0.0.1:8161/admin
【1】Queues
【2】Topics
三。模拟消费者消耗数据
package activemq; import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
import org.apache.activemq.command.ActiveMQMapMessage; import javax.jms.*; /**
* 消息消费者
*/
public class JMSConsumer {
private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;//默认的连接用户名
private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;//默认的连接密码
private static final String BROKERURL = ActiveMQConnection.DEFAULT_BROKER_URL;//默认的连接地址 public static void main(String[] args) {
ConnectionFactory connectionFactory = null;//连接工厂
Connection connection = null;//连接
Session session = null;//会话,接受或者发送消息的线程
Destination destination = null;//消息的目的地
MessageConsumer messageConsumer = null;//消息的消费者
//实例化连接工厂(指定连接用户名|密码|连接地址)
connectionFactory = new ActiveMQConnectionFactory(JMSConsumer.USERNAME, JMSConsumer.PASSWORD, JMSConsumer.BROKERURL);
try {
connection = connectionFactory.createConnection();//通过连接工厂获取连接
connection.start();//启动连接
session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);//创建session
destination = session.createQueue("TestQueue");//创建连接的消息队列(TestQueue:生产者队列名)
messageConsumer = session.createConsumer(destination);//创建消息消费者
while (true) {
MapMessage mapMessage= (MapMessage) messageConsumer.receive(10000);
//TextMessage textMessage= (TextMessage) messageConsumer.receive(10000);//10秒接收
if (mapMessage != null) {
System.out.println("收到的消息:" + ((ActiveMQMapMessage)mapMessage).getContentMap());
} else {
System.out.println("没有消息:");
}
}
} catch (JMSException e) {
e.printStackTrace();
}
}
}
运行代码:
控制台显示:收到的消息:{userName=syf, salary=1000.0, isGirl=true, age=30}
打开浏览器,查看activeMQ监控画面 http://127.0.0.1:8161/admin
【1】Queues(1条消息被消费)
【2】Topics
示例-----企业应用最常见方式之监听器监听方式
增加监听类JMSListener
package activemq; import org.apache.activemq.command.ActiveMQMapMessage; import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
/**
* 消息监听
* */
public class JMSListener implements MessageListener{
public void onMessage(Message message) {
try {
System.out.println("receive Message:"+((ActiveMQMapMessage)message).getContentMap());
} catch (JMSException e) {
e.printStackTrace();
}
}
}
重新模拟一个消费者,应用监听器监听消息
package activemq; import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
import org.apache.activemq.command.ActiveMQMapMessage; import javax.jms.*; public class JMSConsumerByListener {
private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;//默认的连接用户名
private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;//默认的连接密码
private static final String BROKERURL = ActiveMQConnection.DEFAULT_BROKER_URL;//默认的连接地址 public static void main(String[] args) {
ConnectionFactory connectionFactory = null;//连接工厂
Connection connection = null;//连接
Session session = null;//会话,接受或者发送消息的线程
Destination destination = null;//消息的目的地
MessageConsumer messageConsumer = null;//消息的消费者
//实例化连接工厂(指定连接用户名|密码|连接地址)
connectionFactory = new ActiveMQConnectionFactory(JMSConsumerByListener.USERNAME, JMSConsumerByListener.PASSWORD, JMSConsumerByListener.BROKERURL);
try {
connection = connectionFactory.createConnection();//通过连接工厂获取连接
connection.start();//启动连接
session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);//创建session
destination = session.createQueue("TestQueue2");//创建连接的消息队列(TestQueue:生产者队列名)
messageConsumer = session.createConsumer(destination);//创建消息消费者
messageConsumer.setMessageListener(new JMSListener());//注册消息监听
} catch (JMSException e) {
e.printStackTrace();
}
}
}
=》先执行生成者,生产消息!
控制台打印:Sending:{isGirl=true, userName=kaixin, salary=1000.0, age=30}
ActiveMQ监控画面显示:
=》再执行消费者,消费消息!
控制台打印:receive Message:{userName=kaixin, salary=1000.0, isGirl=true, age=30}
ActiveMQ监控画面显示:
OK!!!大功告成!
参考文章:
https://www.toutiao.com/a6345805464718409986/?tt_from=weixin&utm_campaign=client_share&app=news_article&utm_source=weixin&iid=18292470304&utm_medium=toutiao_android&wxshare_count=1
http://blog.csdn.net/xh16319/article/details/12142249
理论博客:http://www.cnblogs.com/Survivalist/p/8094069.html
ActiveMQ学习教程/2.简单示例的更多相关文章
- ActiveMQ学习教程/1.简要介绍与安装
ActiveMQ学习教程(一)——简要介绍与安装 一.名词: 1.JMS:即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的 ...
- SharpDX之Direct2D教程I——简单示例和Color(颜色)
研究Direct2D已经有一段时间了,也写了一个系列的文章 Direct2D ,是基于Windows API Code Pack 1.1.在前文 Direct2D教程VIII——几何(Geometry ...
- ActiveMQ学习教程
一.activemq安装 官网地址:https://activemq.apache.org/ 具体安装过程不赘述,解压即安装, 二.使用 activemq有queue和topic两种模式, 我们以qu ...
- Tensorflow学习教程------softmax简单介绍
做机器学习的同志们应该对这个都不陌生,这里简单举个例子.一般来说,使用softmax函数来将神经元输出的数值映射到0到1之间,这样神经元输出的值就变为了一个概率值. 公式和例子如下图 公式和例子如下图
- RecyclerView(5)官方教程带简单示例
Create Lists The RecyclerView widget is a more advanced and flexible version of ListView. This widge ...
- Playmaker全面实践教程之简单的使用Playmaker示例
Playmaker全面实践教程之简单的使用Playmaker示例 简单的使用Playmaker示例 通过本章前面部分的学习,相信读者已经对Playmaker有了一个整体的认识和印象了.在本章的最后,我 ...
- WebGL简易教程(一):第一个简单示例
目录 1. 概述 2. 示例:绘制一个点 1) HelloPoint1.html 2) HelloPoint1.js (1) 准备工作 (2) 着色器 (3) 顶点着色器 (4) 片元着色器 (5) ...
- Nodejs学习笔记(十五)--- Node.js + Koa2 构建网站简单示例
目录 前言 搭建项目及其它准备工作 创建数据库 创建Koa2项目 安装项目其它需要包 清除冗余文件并重新规划项目目录 配置文件 规划示例路由,并新建相关文件 实现数据访问和业务逻辑相关方法 编写mys ...
- [转]Nodejs学习笔记(十五)--- Node.js + Koa2 构建网站简单示例
本文转自:https://www.cnblogs.com/zhongweiv/p/nodejs_koa2_webapp.html 目录 前言 搭建项目及其它准备工作 创建数据库 创建Koa2项目 安装 ...
随机推荐
- idea控制台搜索框
https://blog.csdn.net/honnyee/article/details/82772948
- 轻松获取LAMP,LNMP环境编译参数配置
轻松获取LAMP,LNMP环境编译参数配置 作者:Mr.Xiong /分类:系统管理 字号:L M S 大家是否遇到过去了新公司,公司内的LAMP,LNMP等所有的环境都是配置好的(已经在提 ...
- tf.split( )和tf.unstack( )
import tensorflow as tf A = [[1, 2, 3], [4, 5, 6]] a0 = tf.split(A, num_or_size_splits=3, axis=1)#不改 ...
- 正则爬取京东商品信息并打包成.exe可执行程序
本文爬取内容,输入要搜索的关键字可自动爬取京东网站上相关商品的店铺名称,商品名称,价格,爬取100页(共100页) 代码如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 1 ...
- 2018山东省赛 H Dominoes ( 搜索 )
题目链接 题意 : 给出一个 n * m 的矩阵,用规格 1 * 2 的多米诺去填充,题目数据保证最后只有一个格子是空白的(即没有被多米诺骨牌覆盖),问你现在通过移动多米诺能够产生多少种不同的状态(空 ...
- HDU 6578 Blank
hdu题面 Time limit 1000 ms Memory limit 262144 kB OS Windows Source 2019 Multi-University Training Con ...
- Updatexml函数再mysql中的作用
函数的解释 http://www.blogjava.net/chenpengyi/archive/2006/07/11/57578.html 我的理解就是updatexml函数具有查询功能 并且会再x ...
- DjangoRESTFrameWork中的视图
DRF中的request 在Django REST Framework中内置的Request类扩展了Django中的Request类,实现了很多方便的功能--如请求数据解析和认证等. 比如,区别于Dj ...
- java dwg转svg
package com.example.demo.dxf2svg; import com.aspose.cad.InterpolationMode; import com.aspose.cad.Smo ...
- Delphi XE2 之 FireMonkey 入门(33) - 控件基础: TFmxObject: SaveToStream、LoadFromStream、SaveToBinStream、LoadFromBinStream
Delphi XE2 之 FireMonkey 入门(33) - 控件基础: TFmxObject: SaveToStream.LoadFromStream.SaveToBinStream.LoadF ...