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 ...
随机推荐
- FlexPaper做的类似百度文库的效果
这里有个误区,虽然我的截图这里有个FlexPaperViewer.swf, 但是这个文件还是要放在网站根目录一个. <%@ Page Language="C#" Auto ...
- fatal: repository 'xxxx' not found
环境:centOS7 背景:公司代码仓库迁移,因而配置的jenkins自动打包git地址也要跟着变化. 问题描述:git clone http xxxx.git后报错: fatal: reposit ...
- Vue知识整理1:$watch方法的使用
如下图所示:vue中,可以使用$watch方法显示变量的前面值和当前值,方便进行判断.使用方法: vm.$watch('a',function(newval,oldval){ ...... })
- VMware 虚拟化编程(6) — VixDiskLib 虚拟磁盘库详解之二
目录 目录 前文列表 VixDiskLib 虚拟磁盘库 VixDiskLib_Open 打开 VMDK File VixDiskLib_Read 读取 VMDK File 数据 VixDiskLib_ ...
- Delphi XE2 之 FireMonkey 入门(20) - TStyleBook(皮肤、样式相关)
我觉得叫 "皮肤" 不如叫 "样式" 或 "风格", 因为它可以包含和动作关联的动画. 在 FMX 下, 控件可以任意绘制, 各部件个性化的 ...
- #Week 11 - 343.Integer Break
Week 11 - 343.Integer Break Given a positive integer n, break it into the sum of at least two positi ...
- elementUi--->实现上传图片效果(upload+formData)
现在谈一下elelmentui中使用Upload 上传通过点击或者拖拽上传文件(图片) <el-upload name="multfile" //上传的文件字段名 cl ...
- python控制流-导入模块
一.模块 1.含义 Python 程序可以调用一组基本的函数,这称为“内建函数”,包括你见到过的 print().input()和 len()函数.Python 也包括一组模块,称为“标准库”.每个模 ...
- python控制流-流程控制语句
一.if语句 if 语句的子句(也就是紧跟 if 语句的语句块), 将在语句的条件为 True 时执行.如果条件为 False,子句将跳过. 在英文中,if 语句念起来可能是“:如果条件为真,执行子句 ...
- JDK11 | 第二篇 : JShell 工具
文章首发于公众号<程序员果果> 地址 : https://mp.weixin.qq.com/s/saHBSTo4OjsIIqv_ixigjg 一.简介 Java Shell工具是JDK1. ...