ActiveMQ 入门使用p2p模型-主动消费
生产者
package clc.active; import com.sun.xml.internal.bind.v2.runtime.unmarshaller.XmlVisitor;
import org.apache.activemq.ActiveMQConnectionFactory; import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageProducer;
import javax.jms.Session; /**
* ClassName: TestProducer<br/>
* Description: 发送一个字符串文本到ActiveMQ<br/>
* date: 2019/1/15 10:16 AM<br/>
*
* @author chengluchao
* @since JDK 1.8
*/ public class TestProducer { /**
* 发送消息到ActiveMQ中,具体的消息内容为参数信息
* 开发JMS相关代码过程中,使用的接口类型都是javax.jms包下的类型.
*
* @param datas - 消息内容.
*/
public void sendTextMessage(String datas) {
//连接工厂
ConnectionFactory factory = null;
//连接
Connection connection = null;
//目的地
Destination destination = null;
//会话
Session session = null;
//消息发送者
MessageProducer producer = null;
//消息对象
Message message = null; try {
//创建连接工厂,连接ActiveMq服务的连接工厂
//创建工厂,构造方法有三个参数,分别是用户名,密码,连接地址
//无参构造,有默认的连接地址,本地连接。localhost
// 单参数构造,无验证模式的,没有用户的认证,
// 三个参数的构造,有认证+指定地址。默认端口是61616
factory = new ActiveMQConnectionFactory("guest", "guest", "tcp://2.2.2.4:61616"); //通过工厂,创建连接对象
//创建连接的方法有重载,其中有createConnection(String username, String password);
//可以再创建爱你连接工厂时,只传递连接地址,不传递用户信息。
connection = factory.createConnection();
//建议启动连接,消息的发送者不是必须启动连接。消息的消费者必须启动连接。
//producer在发送消息的时候,会检查是否启动了连接,如果未启动,自动启动。
//如果有特殊的配置,建议配置完毕后再启动连接
connection.start(); //通过连接对象,创建会话对象。
/*
*创建会话的时候,必须传递两个参数,分别代表是否支持事物和如何确认消息处理。
* transacted - 是否支持事物,数据类型是boolean。true-支持,false-不支持
* true - 支持事物,第二个参数对producer默认无效。建议传递的数据是Session.SESSION_TEANSACTED
* false - 不支持事物,常用参数。第二个参数必须传递,且必须有效。
*
* acknowledgeMode - 如何确认消息的处理。使用确认机制实现的。
* AUTO_ACKNOWLEDGE - 自动确认消息。消息的消费者处理后,自动确认。常用.商业开发不推荐。
* CLIENT_ACKNOWLEDGE - 客户端手动确认,消息的消费者处理后,必须手工确认。
* DUPS_OK_ACKNOWLEDGE - 有副本的客户端手动确认。
* 一个消息可以多次处理。
* 可以略低Session的消耗,在可以容忍重复消息时使用(不推荐使用)
*/ session = connection.createSession(false, Session.CLIENT_ACKNOWLEDGE);
//创建目的地,
destination = session.createQueue("first-mq"); //通过会话对象,创建爱你消息的发送者producer
//创建的消息发送者,发送的消息一定到指定的目的地中。
//创建producer的时候可以不指定目的地,在发送消息的时候指定目的地。
producer = session.createProducer(destination);
//创建文本消息对象,作为具体数据内容的载体。
message = session.createTextMessage(datas); //使用producer发送消息到ActiveMQ的目的地,如果消息发送失败,抛出异常
producer.send(message); System.out.println("消息已发送"); } catch (Exception e) {
e.printStackTrace();
} finally {
// 回收资源
//消息发送者
if (producer != null) {
try {
producer.close();
} catch (JMSException jmse) {
jmse.printStackTrace();
}
}
//会话对象
if (session != null) {
try {
session.close();
} catch (JMSException jmse) {
jmse.printStackTrace();
}
}
//连接对象
if (connection != null) {
try {
connection.close();
} catch (JMSException jmse) {
jmse.printStackTrace();
}
}
}
} public static void main(String[] args) {
TestProducer producer = new TestProducer();
producer.sendTextMessage("clccc");
}
}
消费者:
package clc.active; import org.apache.activemq.ActiveMQConnectionFactory;
import org.testng.annotations.Test; import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.Queue;
import javax.jms.Session;
import javax.jms.TextMessage; /**
* ClassName: TestConsumer<br/>
* Description: 消费消息<br/>
* date: 2019/1/15 11:21 AM<br/>
*
* @author chengluchao
* @since JDK 1.8
*/ public class TestConsumer {
/**
* 消费消息
*
* @throws Exception
*/
@Test
public void TestMQConsumerQueue() throws Exception {
//1、创建工厂连接对象,需要制定ip和端口号
ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://2.2.2.4:61616");
//2、使用连接工厂创建一个连接对象
Connection connection = connectionFactory.createConnection();
//3、开启连接
connection.start();
//4、使用连接对象创建会话(session)对象
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//指定目的地获取消息
Destination destination = session.createQueue("first-mq"); //6、使用会话对象创建生产者对象
MessageConsumer consumer = session.createConsumer(destination);
//获取队列中的消息,receive方法是一个主动获取消息的订单,执行一次,拉取一个消息
Message message = consumer.receive(); System.out.println(((TextMessage) message).getText()); //、关闭资源
consumer.close();
session.close();
connection.close();
} }
ActiveMQ 入门使用p2p模型-主动消费的更多相关文章
- ActiveMQ P2P模型 观察者消费
生餐者: package clc.active.listener; import org.apache.activemq.ActiveMQConnectionFactory; import org.t ...
- ActiveMQ之一--ActiveMQ入门
MQ的消费-生产者模型的一个典型的代表,一端往消息队列中不断的写入消息,而另一端则可以读取或者订阅队列中的消息.MQ和JMS类似,但不同的是JMS是SUN JAVA消息中间件服务的一个标准和API定义 ...
- ActiveMQ入门系列二:入门代码实例(点对点模式)
在上一篇<ActiveMQ入门系列一:认识并安装ActiveMQ(Windows下)>中,大致介绍了ActiveMQ和一些概念,并下载.安装.启动他,还访问了他的控制台页面. 这篇,就用代 ...
- ActiveMQ入门练习
ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线.ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久 ...
- jms - activeMQ入门案例
activeMQ入门案例 叨叨一波,很久没写博客了,最近比较慢,时间抽不出来,这个借口说的很尴尬...我知道作为一名合格的码农就必须养成每天一博客的习惯.希望友友们别像我这样懒,闲话不多时进入今天的主 ...
- 深入浅出 JMS(二) - ActiveMQ 入门指南
深入浅出 JMS(二) - ActiveMQ 入门指南 上篇博文深入浅出 JMS(一) – JMS 基本概念,我们介绍了消息通信的规范JMS,这篇博文介绍一款开源的 JMS 具体实现-- Active ...
- ActiveMQ 入门和与 Spring 整合
ActiveMQ 入门演示 activemq 依赖 <dependency> <groupId>org.apache.activemq</groupId> < ...
- ActiveMQ入门系列三:发布/订阅模式
在上一篇<ActiveMQ入门系列二:入门代码实例(点对点模式)>中提到了ActiveMQ中的两种模式:点对点模式(PTP)和发布/订阅模式(Pub & Sub),详细介绍了点对点 ...
- ActiveMQ 入门Nodejs版
ActiveMQ 入门下载与安装 官方下载地址 解压,运行bin/win[32|64]/activemq[.bat] 启动服务 环境信息 控制台: http://localhost:8161 默认端口 ...
随机推荐
- BZOJ1922 [Sdoi2010]大陆争霸 【最短路】
题目 在一个遥远的世界里有两个国家:位于大陆西端的杰森国和位于大陆东端的 克里斯国.两个国家的人民分别信仰两个对立的神:杰森国信仰象征黑暗和毁灭 的神曾·布拉泽,而克里斯国信仰象征光明和永恒的神斯普林 ...
- 【2018.10.27】CXM笔记
一个数大约有 $O(\sqrt(n)/log^2(n))$ 个约数. 1. 一个棋盘,每个格子最开始都是白的.可以按一个格子,它马跳(日字跳)能到达的 $8$ 个格子反色(当前格不反色).问有多少种方 ...
- robotframework使用
下面是ui自动化的使用,关于接口自动化的使用参照此博客:http://blog.csdn.net/wuxiaobingandbob/article/details/50747125 1.使用pytho ...
- Codevs 5564 陶陶摘苹果2
5564 陶陶摘苹果2 时间限制: 1 s 空间限制: 16000 KB 题目等级 : 白银 Silver 题目描述 Description 陶陶已经够高摘到所有苹果了,但是他力量有限,最大承受质量为 ...
- Codeforces737E. Tanya is 5!
$n \leq 40$个人玩$m \leq 10$台游戏机,每台游戏机一秒内只能一人玩,每人一秒内只能玩一台.每台游戏机有个价格,在规定总价格内可以把一部分游戏机复制一次,每台只能复制一次.给每个人对 ...
- 关于EOF,转自新浪微博
本文转自http://blog.sina.com.cn/s/blog_7714171f0101798y.html EOF 是 End Of File 的缩写. 在C语言中,它是在标准库中定义的一个宏. ...
- git status检测不到文件变化
SourceTree(Git)无法检测新增文件的解决方法 有时候使用git管理软件SourceTree会遇到往项目里新增了文件,软件却没有任何反应的问题,这多发生在git合并出错而只能重新git的情况 ...
- P1540 机器翻译(STL 链表)
题目背景 小晨的电脑上安装了一个机器翻译软件,他经常用这个软件来翻译英语文章. 题目描述 这个翻译软件的原理很简单,它只是从头到尾,依次将每个英文单词用对应的中文含义来替换.对于每个英文单词,软件会先 ...
- T2639 约会计划 codevs
http://codevs.cn/problem/2639/ 题目描述 Description cc是个超级帅哥,口才又好,rp极高(这句话似乎降rp),又非常的幽默,所以很多mm都跟他关系不错.然而 ...
- 深究Spring中Bean的生命周期
前言 这其实是一道面试题,是我在面试百度的时候被问到的,当时没有答出来(因为自己真的很菜),后来在网上寻找答案,看到也是一头雾水,直到看到了<Spring in action>这本书,书上 ...