ActiveMQ点对点模式
1.安装ActiveMQ服务器(略)
2.启动ActiveMQ,浏览器访问8161端口,默认账号admin/admin

3. 生产者代码
package test001;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;import javax.jms.*;
/**
* @Created by zhengqinfeng
* @Description :
* @Date : created in 23:44 2018/5/14
*/
public class ProducerMQ {
public static void main(String[] args) throws JMSException {
//创建MQ工厂
ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, "tcp://localhost:61616");
//创建连接
Connection connection = factory.createConnection();
//启动连接
connection.start();
//创建会话工厂, false:表示不以事务方式进行提交; Session.AUTO_ACKNOWLEDGE 表示自动签收
// Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//Session.CLIENT_ACKNOWLEDGE:手动签收
Session session = connection.createSession(false, Session.CLIENT_ACKNOWLEDGE);
//创建队列
Queue testMQ = session.createQueue("testMQ1");
//创建生产者
MessageProducer producer = session.createProducer(testMQ);
//消息不持久化
// producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
//持久化消息
//producer.setDeliveryMode(DeliveryMode.PERSISTENT);
for (int i = 0; i <= 10; i++) {
System.out.println("###########我是生产者:"+i+"###############");
sendMsg(session, producer, "我是生产者:" + i);
}
System.out.println("###########发送消息完毕###############");}
private static void sendMsg(Session session,MessageProducer producer,String i) throws JMSException {
TextMessage textMessage = session.createTextMessage("hello activeMQ " + i);
producer.send(textMessage);
}
}
4.消费者代码
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;import javax.jms.*;
/**
* @Created by zhengqinfeng
* @Description : 消费者
* @Date : created in 12:47 2018/5/15
*/
public class ConsumerMQ {
public static void main(String[] args) throws JMSException {
System.out.println("消费者1");
//创建MQ工厂
ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER, ActiveMQConnection.DEFAULT_PASSWORD, "tcp://localhost:61616");
//创建连接
Connection connection = factory.createConnection();
//启动连接
connection.start();
//创建会话工厂 AUTO_ACKNOWLEDGE:自动签收
// Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
// 手动签收
Session session = connection.createSession(false, Session.CLIENT_ACKNOWLEDGE);
//创建队列
Queue testMQ = session.createQueue("testMQ1");
//创建生产者
MessageConsumer consumer = session.createConsumer(testMQ);//第一种消费消息的方式
// while (true) {
// //获取消息
// TextMessage message = (TextMessage) consumer.receive();
// if (message != null) {
// String text = message.getText();
// System.out.println("消费者获取消息,text:" + text);
// //手动签收,如果没有手动签收,消息还是会存在于队列中的(当然这是在Session.CLIENT_ACKNOWLEDGE模式下)
// message.acknowledge();
// } else {
// break;
// }
// }
// System.out.println("消费者获取消息完毕>>>>>>>>>>>>>>>>>>>..");//第二种消费消息的方式
consumer.setMessageListener(new MessageListener() {
@Override
public void onMessage(Message message) {
TextMessage m = (TextMessage) message;
try {
System.out.println("消费者获取消息:"+m.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
});
}
}
启动消费者代码,然后修改System.out.println("消费者1")为System.out.println("消费者2"),再次启动。模拟测试两个消费者


启动生产者

再查看消费者1:

查看消费者2:

结论:消费1和消费者均摊消费testMQ1这个队列中的消息。
ActiveMQ点对点模式的更多相关文章
- springBoot配置activeMq点对点模式消费信息以及独占模式消费如何设置
1.在pom文件中引入对应jar包 <!--activeMQ start--> <dependency> <groupId>org.springframework. ...
- JMS-activeMq点对点模式
上一篇对JMS进行介绍了一下,接下来总结一下activemq点对点模式以及订阅发布模式. (1)下载:首先到官网http://activemq.apache.org下载activemq (2)运行:解 ...
- ActiveMQ入门系列二:入门代码实例(点对点模式)
在上一篇<ActiveMQ入门系列一:认识并安装ActiveMQ(Windows下)>中,大致介绍了ActiveMQ和一些概念,并下载.安装.启动他,还访问了他的控制台页面. 这篇,就用代 ...
- ActiveMQ点对点的消息发送案例
公司最近会用MQ对某些业务进行处理,所以,这次我下载了apache-activemq-5.12.0-bin把玩下. 基于练习方便需要,使用Windows的版本. 参考的优秀文章: activemq的几 ...
- activeMQ点对点
摘要: ActiveMQ 点对点消息 Point-to-Point 是一对一 创建消息生产者 /** * 点对点消息生产者 * * @author Edward * */ public ...
- ActiveMQ发布-订阅消息模式(同点对点模式的区别)
点对点与发布订阅最初是由JMS定义的.这两种模式主要区别或解决的问题就是发送到队列的消息能否重复消费(多订阅) 点对点: 消息生产者生产消息发送到queue中,然后消息消费者从queue中取出并且消费 ...
- SpringBoot2.0之整合ActiveMQ(点对点模式)
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...
- ActiveMQ订阅模式持久化实现
实现步骤:1.配置发送xml,applicationContext-send.xml <?xml version="1.0" encoding="UTF-8&quo ...
- activeMQ队列模式和主题模式的Java实现
一.队列模式 生产者 import javax.jms.Connection; import javax.jms.ConnectionFactory; import javax.jms.Destina ...
随机推荐
- leetcode 39. 组合总和(python)
给定一个无重复元素的数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合. candidates 中的数字可以无限制重复被选 ...
- Understanding ECMAScript 6 阅读问题小记
拖了一年说要看这本书,一直都没坚持下来,开个 bo 记录下觉得疑惑的问题,也算鞭策一下自己. 第一章 块级绑定 1. 第一章“块级绑定”下,说 const 变量如果绑定的是对象 Object,那么修改 ...
- JSP不支持EL表达式的解决方案
EL的全称是Expression Language.1.在默认情况下,Servlet 2.3 / JSP 1.2是不支持EL表达式的,而Servlet 2.4 / JSP 2.0支持. servlet ...
- 关于Vue的理解以及与React框架的对比
1.Vue的理解 概念: Vue是一套用于构建用户界面的渐进式框架: Vue的核心库只关注视图层: 是一个数据驱动的MVVM框架: 特性: 确实轻量:体积比较小: 数据绑定简单.方便: 有一些简单的内 ...
- 排序算法七:基数排序(Radix sort)
上一篇提到了计数排序,它在输入序列元素的取值范围较小时,表现不俗.但是,现实生活中不总是满足这个条件,比如最大整形数据可以达到231-1,这样就存在2个问题: 1)因为m的值很大,不再满足m=O(n) ...
- Windows + Ubuntu 16.04 双系统安装详细教程(转)
转载自:http://www.cnblogs.com/Duane/p/6776302.html 前言:本篇文章是对之前文章的更新,更新的主内容是把原来用手机拍摄的图片换成了虚拟机的截图,以及对磁盘划分 ...
- spring-data-redis的使用/redis缓存
1.导入依赖 <properties> <junit.version>4.12</junit.version> <spring.version>4.2. ...
- echarts柱状图个数多,横坐标名称过长显示不全解决方法
当echarts柱状图个数多,横坐标名称过长时横坐标名称显示不全,网上并没有搜到太好的方法,于是自己加工了下,将横坐标名称显示前六位,当鼠标放到上面的时候显示全名,下面是示例代码,可以直接拷贝测试 代 ...
- CentOS7搭建Docker镜像实战
开发十年,就只剩下这套架构体系了! >>> 一.搭建环境 使用的是VMWare 12虚拟机安装的CentOS7 安装成功后修改ip: 1. ip addr查看相关信息: 2. 修 ...
- markdown简介及基本语法
一.前言 Markdown是一种轻量级标记语言,它以纯文本形式(易读.易写.易更改)编写文档,并最终以HTML格式发布. Markdown也可以理解为将以MARKDOWN语法编写的语言转换成HTML内 ...